## CMOS 8-Bit Microcontroller <br> TMP88CS38BNG/FG, TMP88CM38BNG/FG, TMP88CP38BNG/FG

The TMP88CS38B/CM38B/CP38B is the high speed and high performance 8 -bit single chip microcomputers. This MCU contain CPU core, ROM, RAM, input/output ports, four Multi-function timer/counters, serial bus interface, on-screen display, PWM output, 8-bit AD converter, and remote control signal preprocessor on chip.

| Product No. | ROM | RAM | Package | OTP MCU |
| :---: | :---: | :---: | :---: | :---: |
| TMP88CS38BNG/FG | $64 \mathrm{~K} \times 8$ bits | $2 \mathrm{~K} \times 8$ bits | SDIP42-P-600-1.78 | TMP88PS38BNG/FG |
| TMP88CM38BNG/FG | $32 \mathrm{~K} \times 8$ bits | $1.5 \mathrm{~K} \times 8$ bits |  |  |
| TMP88CP38BNG/FG | $48 \mathrm{~K} \times 8$ bits |  |  |  |

## Features

- 8-bit single chip microcomputer TLCS-870/X series
- Instruction execution time: $0.25 \mu \mathrm{~s}$ (at 16 MHz )
- 842 basic instructions
- Multiplication and division ( 8 bits $\times 8$ bits, 16 bits $\times 8$ bits, 16 bits $/ 8 \mathrm{bits}$ )
- Bit manipulations (Set/clear/complement/move/test/exclusive or)
- 16-bit data and 20-bit data operations
- 1-byte jump/subroutine call (Short relative jump/vector call)
- I/O ports: Maximum 33 (High current output: 4)
- 17 interrupt sources: External 6, internal 11
- All sources have independent latches each, and nested interrupt control is available.
- Edge-selectable external interrupts with noise reject
- High-speed task switching by register bank changeover
- ROM corrective function
- Two 16-bit timer/counters: TC1, TC2
- Timer, event counter, pulse width measurement, external trigger timer, window modes

030619EBP1

- The information contained herein is subject to change without notice.
- The information contained herein is presented only as a guide for the applications of our products. No responsibility is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others.
- TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such TOSHIBA products could cause loss of human life, bodily injury or damage to property.
In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc..
- The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunctionor failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc.. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk.
- The products described in this document are subject to the foreign exchange and foreign trade laws.
- TOSHIBA products should not be embedded to the downstream products which are prohibited to be produced and sold, under any law and regulations.
- For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions.

Purchase of TOSHIBA $\mathrm{I}^{2} \mathrm{C}$ components conveys a license under the Philips $\mathrm{I}^{2} \mathrm{C}$ Patent Rights to use these components in an $\mathrm{I}^{2} \mathrm{C}$ system, provided that the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ Standard Specification as defined bv Philins.

- Two 8-bit timer/counters: TC3, TC4
- Timer, event counter, capture (Pulse width/duty measurement) mode
- Time base timer (Interrupt frequency: 0.95 Hz to 31250 Hz )
- Watchdog timer
- Interrupt sourse/reset output
- Serial bus interface
- $\quad \mathrm{I}^{2} \mathrm{C}$ bus, 8 -bit SIO mode (Selectable two I/O channels)
- On-screen display circuit
- Font ROM characters: 384 characters
- Characters display: 32 columns $\times 12$ lines
- Composition: $16 \times 18$ dots
- Size of character: 3 kinds (Line by line)
- Color of character: 8 or 15 kinds (Character by character)
- Variable display position: Horizontal 256 steps, Vertical 512 steps
- Fringing, smoothing, slant, underline, blinking function
- Jitter elimination
- Data slicer circuit 1 channel
- DA conversion (Pulse width modulation) outputs
- 14 - or 12 -bit resolution ( 2 channels)
- 12-bit resolution (2 channels)
- 7-bit resolution (6 channels)
- 8-bit successive approximate type AD converter with sample and hold
- Remote control signal preprocessor
- Two power saving operating modes
- STOP mode: Oscillation stops. Battery/capacitor back up. Port output hold/high impedance.
- IDLE mode: CPU stops, and peripherals operate using high-frequency clock. Release by interrupts.
- Operating Voltage: 4.5 to 5.5 V at 16 MHz
- Emulation POD: BM88CS38N0A-M15


## Pin Assignments



## Pin Functions (1/2)

| Pin Name | I/O | Function |  |
| :---: | :---: | :---: | :---: |
| P 20 ( $\overline{\mathrm{INT5}} / \overline{\text { STOP }}$ ) | I/O (Input) | 1-bit input/output port with latch. When used as an input port, the latch must be set to " 1 ". | External interrupt input 5 or STOP mode release signal input |
| P35 (SDA0) | I/O (Input/Output) | 6-bit programmable input/output port. Each bit of these ports can be individually configured as an input or an output under software control. During reset, all bits are configured as inputs. When used as a serial bus interface input/output, the latch must be set to " 1 ". | $1^{2} \mathrm{C}$ bus serial data input/output 0 |
| P34 (SCL0) | I/O (Input/Output) |  | $\mathrm{I}^{2} \mathrm{C}$ bus serial clock input/output 0 |
| P33 (TC4/VIN0) | I/O (Input) |  | Timer counter input 4 or video signal Input 0 |
| P32 (VIN1/CSIN) | I/O (Input) |  | Video signal input 1 or composite sync input |
| P31 (INT4/TC3) | I/O (Input) |  | External interrupt input 4 or timer counter input 3 |
| P30 (INT3/RXIN) | I/O (Input) |  | External interrupt input 3 or remote control signal preprocessor input |
| P47 ( $\overline{\text { PWM7 }}$ ) | I/O (Output) | 8-bit programmable input/output port. Each bit of these ports can be individually configured as an input or an output under software control. During reset, all bits are configured as inputs. When used as a PWM output, the latch must be set to " 1 ". | 7-bit DA conversion (PWM) outputs |
| P46 ( $\overline{\text { PWM6 }}$ ) | I/O (Output) |  |  |
| P45 ( $\overline{\text { PWM5 }}$ ) | I/O (Output) |  |  |
| P44 ( $\overline{\text { PWM4 }}$ ) | I/O (Output) |  |  |
| P43 ( $\overline{\text { PWM3 }}$ ) | I/O (Output) |  | 12-bit DA conversion (PWM) outputs |
| P42 ( $\overline{\text { PWM2 }}$ ) | I/O (Output) |  |  |
| P41 ( $\overline{\text { PWM1 }}$ ) | I/O (Output) |  | 14/12-bit DA conversion (PWM) outputs |
| P40 ( $\overline{\text { PWM0 }}$ ) | I/O (Output) |  |  |
| P57 (I) | I/O (Output) | 8-bit programmable input/output port. Each bit of these ports can be individually configured as an input or an output under software control. During reset, all bits are configured as inputs. When used as a PWM output, a serial bus interface input/output, the latch must be set to " 1 ". | Translucent signal output |
| P56 ( $\overline{\text { KWU3 }} / \mathrm{AIN3}$ ) | I/O (Input) |  | Key-on wakeup inputs or AD converter analog inputs |
| P55 ( $\overline{\text { KWU2 }}$ /AIN2) | I/O (Input) |  |  |
| P54 ( $\overline{\text { KWU1 } / A I N 1) ~}$ | I/O (Input) |  |  |
| P53 ( $\overline{\text { KWUO }} /$ AINO/TC1 /INT2/ SCK1) | I/O <br> (Input /Input/Input /Input/Output) |  | Key-on wakeup input or AD converter analog input or timer counter input 1 or external interrupt input 2 or SIO serial clock input/output 1 |
| P52 (SDA1/SO1) | I/O <br> (Input/Output /Output) |  | $I^{2} \mathrm{C}$ bus serial data input/output 1 or SIO serial data output 1 |
| P51 ( $\overline{\text { PWM9 }} / \mathrm{SCL1} / \mathrm{SI} 1)$ | I/O (Output/Input/Output /Input) |  | 7-bit DA conversion (PWM) output or $1^{2} \mathrm{C}$ bus serial data input/output 1 or SIO serial data input 1 |
| P50 ( $\overline{\text { PWM8 }} / \mathrm{TC} 2 / \overline{\mathrm{NTT}}$ ) | I/O (Output/Input /Input) |  | 7-bit DA conversion (PWM) output or timer counter input 2 or external interrupt input 0 |
| P67 (Y/BL) | I/O (Output) | 8-bit programmable input/output port. (P67 to P64: Tri-State, P63 to P60: High current output) Each bit of these ports can be individually configured as an input or an output under software control. During reset, all bits are configured as inputs. When used P64 to P67 as port, each bit of the P6 port data selection register (Bit7 to 4 in ORP6S) must be set to " 1 ". | Y or BL output |
| P66 (B) | I/O (Output) |  | R/G/B outputs |
| P65 (G) | I/O (Output) |  |  |
| P64 (R) | I/O (Output) |  |  |
| P63 (RIN) | I/O (Input) |  | R input |
| P62 (GIN/CSOUT) | I/O (Input/Output) |  | G input or TEST video signal output |
| P61 ( $\overline{\text { KWU5 }} / \mathrm{BIN} / \mathrm{AIN5}$ ) | I/O (Input) |  | Key-on wakeup input 5 or B input or AD converter analog input 5 |
| $\begin{aligned} & \mathrm{P} 60 \\ & (\mathrm{KWU4} / \mathrm{YBLIN} / A I N 4) \end{aligned}$ | I/O (Input) |  | Key-on wakeup input 4 or Y/BL input or AD converter analog input 4 |

Pin Functions (2/2)

| Pin Name | I/O | Function |  |
| :--- | :---: | :--- | :--- |
| P71 ( $\overline{\mathrm{VD}})$ | I/O (Input) | 2-bit programmable input/output port. <br> Each bit of these ports can be <br> individually configured as an input or <br> an output under software control. <br> During reset, all bits are configured as <br> inputs. | Vertical synchronous signal input |
| P70 ( $\overline{\mathrm{HD}})$ | I/O (Input) | Horizontal synchronous signal input |  |
| XIN, XOUT | Input, Output | Resonator connecting pins. For inputting external clock, XIN is used and XOUT <br> is opened. |  |
| RESET | I/O | Reset signal input or watchdog timer output/address-trap-reset <br> output/system-clock-reset output |  |
| TEST | Input | Test pin for out-going test. Be tied to low. |  |
| OSC1, OSC2 | Input, Output | Resonator connecting pins for on-screen display circuitry |  |
| VDD, VSS, VVSS | Power supply | +5 V, O V (GND) |  |

Block Diagram


## Operational Description

## 1. CPU Core Functions

The CPU core consists of a CPU, a system clock controller, and an interrupt controller.
This section provides a description of the CPU core, the program memory, the data memory, the external memory interface, and the reset circuit.

### 1.1 Memory Address Map

The TMP88CS38B/CM38B/CP38B memory consists of four blocks: ROM, RAM, SFR (Special function register), and DBR (Data buffer register). They are all mapped to a 1 -Mbyte address space. Figure 1.1 .1 shows the TMP88CS38B/CM38B/CP38B memory address map. There are 16 banks of the general-purpose register. The register banks are also assigned to the RAM address space.


Figure 1.1.1 Memory Address Map

### 1.2 Program Memory (ROM)

The TMP88CS38B contains a 64 -Kbyte program memory (Mask ROM) at addresses from 04000 H to 13 EFFH and FFF00H to FFFFFH.

The TMP88CM38B contains a 32 -Kbyte program memory (Mask ROM) at address from 04000 H to 0BEFFH and FFF00H to FFFFFH. The TMP88CP38B contains a 48 - Kby te program memory (Mask ROM) at address from 04000 H to 0FEFFH and FFF00H to FFFFFH.

Addresses FFF00H through FFFFFH in the program memory are also used for a particular purpose.

### 1.3 Data Memory (RAM)

The TMP88CS38B has a 2 -Kbyte data memory (Static RAM) address from 0040H to 08BFH.
The TMP88CM38B/CP38B has a 1.5 -Kbyte data memory (Static RAM) address from 0040H to 06 BFH .

The first 128 bytes (Addresses 00040 H through 000 BFH ) in the built-in RAM are also available as general-purpose register banks.

The general-purpose registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses.

Example: Clears RAM to "00H" except the bank0 (TMP88CS38B/CM38B/CP38B):

| LD | HL, 0048H | $;$ | Sets start address to HL register pair |
| :--- | :--- | :--- | :--- |
| LD | A, H | St | Sets initial data (00H) to A register |
| LD | BC, 0877H | $;$ | Sets number of byte to BC register pair |
| SRAMCLR $:$ | $(H L+)$, A |  |  |
| DEC | BC |  |  |
| JRS | F, SRAMCLR |  |  |

Note: The data memory contents become unstable when the power supply is turned on; therefore, the data memory should be initialized by an initialization routine. Note that the general-purpose registers are mapped in the RAM; therefore, do not clear RAM at the current bank addresses.

### 1.4 System Clock Controller

The system clock controller consists of a clock generator, a timing generator, and a standby controller.


Figure 1.4.1 System Clock Controller

### 1.4.1 Clock Generator

The clock generator generates the basic clock which provides the system clocks supplied to the CPU core and peripheral hardware. It contains oscillation circuit: one for the high-frequency clock.
The high-frequency (fc) clock can be easily obtained by connecting a resonator between the XIN/XOUT pin, respectively. Clock input from an external oscillator is also possible. In this case, external clock is applied to the XIN/XTIN pin not connected. The TMP88CS38B/CM38B/CP38B is not provided an LC oscillation.


Figure 1.4.2 Examples of Resonator Connection

Note: Accurate adjustment of the oscillation frequency:
Although hardware to externally and directly monitor the basic clock pulse is not provided, the oscillation frequency can be adjusted by making the program to output fixed frequency pulses to the port while disabling all interrupts and monitoring this pulse. With a system requiring adjustment of the oscillation frequency, the adjusting program must be created beforehand.

### 1.4.2 Timing Generator

The timing generator generates from the basic clock the various system clocks supplied to the CPU core and peripheral hardware. The timing generator provides the following functions:

1. Generation of main system clock
2. Generation of source clocks for time base timer
3. Generation of source clocks for watchdog timer
4. Generation of internal source clocks for timer/counters TC1 to TC4
5. Generation of warm-up clocks for releasing STOP mode
6. Generation of a clock for releasing reset output
(1) Configuration of timing generator

The timing generator consists of a 21 -stage divider with a divided by 3 prescaler, a main system clock generator, and machine cycle counters.
During reset and at releasing STOP mode, the prescaler and the divider are cleared to " 0 ", however, the prescaler is not cleared.
An input clock to the 7th stage of the divider depends on the operating mode.
A divided by 256 of high-frequency clock ( $\mathrm{fc} / 2^{8}$ ) is input to the 7 th stage of the divider.


Figure 1.4.3 Configuration of Timing Generator

| $\begin{aligned} & \text { CGCR } \\ & (00030 H) \end{aligned}$ | ---------" ${ }^{\text {cos }}$ |  |  | (Initial value: 0000 0000) |
| :---: | :---: | :---: | :---: | :---: |
|  | DV1CK | Selection of input clock to the 1st stage of the divider. | $\begin{aligned} & \mathrm{0}: \mathrm{fc} / 4 \\ & \text { 1: fc/8 } \end{aligned}$ | R/W |
|  | Note 1: fc: High-frequency clock [Hz], *: Don't care <br> Note 2: The all bits except DV1CK are cleared to " 0 ". |  |  |  |

Figure 1.4.4 Divider Control Register

| $\begin{aligned} & \text { FC8CR } \\ & \text { (00FEEH) } \end{aligned}$ |  |  | D1 | D0 | Read/Write (Initial value: 0000 0010) |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | D1 | D0 | FC8OUT |  |  |
|  | 1 | 0 | $1 / 2 \mathrm{fc}$ |  |  |
|  | 0 | 0 | 1/1 fc |  |  |

Figure 1.4.5 FC8 Control Register
(2) Machine cycle

Instruction execution and peripheral hardware operation are synchronized with the main system clock. The minimum instruction execution unit is called a "machine cycle". There are a total of 15 different types of instructions for the TLCS-870/X series: Ranging from 1-cycle instructions which require one machine cycle for execution to 15 -cycle instructions which require 15 machine cycles for execution.

A machine cycle consists of 4 states ( S 0 to S 3 ), and each state consists of one main system clock.


Figure 1.4.6 Machine Cycle

### 1.4.3 Standby Controller

The standby controller starts and stops the switches the main system clock. These modes are controlled by the system control registers (SYSCR1, SYSCR2).

Figure 1.4 .7 shows the operating mode transition diagram and Figure 1.4 .8 shows the system control registers.
(1) Single-clock mode

In the single-clock mode, the machine cycle time is $4 / \mathrm{fc}[\mathrm{s}](0.25 \mu \mathrm{~s}$ at fc $=16 \mathrm{MHz})$.

1. NORMAL mode

In this mode, both the CPU core and on-chip peripherals operate using the high-frequency clock.
2. IDLE mode

In this mode, the internal oscillation circuit remains active. The CPU and the watchdog timer are halted; however, on-chip peripherals remain active (Operate using the high-frequency clock). IDLE mode is started by setting IDLE bit in the system control register 2 (SYSCR2), and IDLE1 mode is released to NORMAL mode by an interrupt request from on-chip peripherals or external interrupt inputs. When IMF (Interrupt master enable flag) is " 1 " (Interrupt enable), the execution will resume upon acceptance of the interrupt, and the operation will return to normal after the interrupt service is completed. When IMF is " 0 " (Interrupt disable), the execution will resume with the instruction which follows IDLE mode start instruction.
3. STOP mode

In this mode, the internal oscillation circuit is turned off, causing all system operations to be halted. The internal status immediately prior to the halt is held with the lowest power consumption during this mode.

STOP mode is started by setting STOP bit in the system control register 1 (SYSCR1), and STOP mode is released by an input (Either level-sensitive or edge-sensitive can be programmably selected) to the $\overline{\text { STOP }}$ pin. After the warm-up period is completed, the execution resumes with the next instruction which follows the STOP mode start instruction.


Figure 1.4.7 Operating Mode Transition Diagram

System Control Register 1


| STOP | STOP mode start | 0: CPU core and peripherals remain active <br> 1: CPU core and peripherals are halted (Start STOP mode) |  |  | R/W |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RELM | Release method for STOP mode | $\begin{array}{ll} 0: & \overline{\mathrm{STO}} \\ 1: & \overline{\mathrm{STO}} \end{array}$ | dge-sensitive vel-sensitive | sing edge) " level) |  |
| WUT | Warm-up time at releasing STOP mode |  | Return to NORMAL mode |  |  |
|  |  |  | DV1CK = 0 | DV1CK = 1 |  |
|  |  | 00 | $3 \times 2^{16} / \mathrm{fc}$ | $3 \times 2^{17} / \mathrm{fc}$ |  |
|  |  | 01 | $2^{16} / \mathrm{fc}$ | $2^{17} / \mathrm{fc}$ |  |
|  |  | 10 | $3 \times 2{ }^{14} / \mathrm{fc}$ | $3 \times 2{ }^{15} / \mathrm{fc}$ |  |
|  |  | 11 | $2^{14} / \mathrm{fc}$ | $2^{15} / \mathrm{fc}$ |  |

Note 1: Always set bit5 in SYSCR1 to "0".
Note 2: When STOP mode is released with $\overline{\text { RESET }}$ pin input, a return is made to NORMAL mode regardless of the RETM contents.
Note 3: fc: High-frequency clock [Hz]
*: Don't care
Note 4: Bits 1 and 0 in SYSCR1 are read in as undefined data when a read instruction is executed.
Note 5: Always set bit4 in SYSCR1 to " 1 " when STOP mode is started.

System Control Register 2


| IDLE | IDLE mode start | 0: CPU and watchdog timer remain active <br> $1: C P U ~ a n d ~ w a t c h d o g ~ t i m e r ~ a r e ~ s t o p p e d ~(S t a r t ~ I D L E ~ m o d e) ~$ | R/W |
| :---: | :--- | :--- | :--- |

Note 1: *: Don't care
Note 2: Always set bit7, 6 and 5 in SYSCR2 to " 100 ".

Figure 1.4.8 System Control Registers

### 1.4.4 Operating Mode Control

(1) STOP mode

STOP mode is controlled by the system control register 1 (SYSCR1) and the $\overline{\text { STOP }}$ pin input. The $\overline{\text { STOP }}$ pin is also used both as a port P20 and an INT5 (External interrupt input 5) pin. STOP mode is started by setting STOP (Bit7 in SYSCR1) to " 1 ". During STOP mode, the following status is maintained.

1. Oscillations are turned off, and all internal operations are halted.
2. The data memory, registers and port output latches are all held in the status in effect before STOP mode was entered.
3. The prescaler and the divider of the timing generator are cleared to " 0 ".
4. The program counter holds the address of the instruction following the instruction which started the STOP mode.
STOP mode includes a level-sensitive release mode and an edge-sensitive release mode, either of which can be selected with RELM (Bit6 in SYSCR1).
a. Level-sensitive release mode $(\operatorname{RELM}=1)$

In this mode, STOP mode is released by setting the STOP pin high. This mode is used for capacitor back up when the main power supply is cut off and long term battery back up.

When the $\overline{\text { STOP }}$ pin input is high, executing an instruction which starts the STOP mode will not place in STOP mode but instead will immediately start the release sequence (Warm up). Thus, to start STOP mode in the level-sensitive release mode, it is necessary for the program to first confirm that the $\overline{\mathrm{STOP}}$ pin input is low. The following method can be used for confirmation:

Using an external interrupt input $\overline{\text { INT5 }}$ ( $\overline{\text { INT5 }}$ is a falling edge-sensitive input).

Example: Starting STOP mode with an INT5 interrupt.

| PINT5: | TEST | (P2). 0 | To reject noise, the STOP mode does not start |
| :---: | :---: | :---: | :---: |
|  | JRS | F, SINT5 | if port P20 is at high |
|  | LD | (SYSCR1), 01010000B | Sets up the level-sensitive release mode |
|  | SET | (SYSCR1). 7 | Starts STOP mode |
|  | LDW | (IL), 1110011101010111B | IL ${ }_{12}, 11,7,5,3 \leftarrow 0$ (Clears interrupt latches) |
| SINT5: | RETI |  |  |

$\overline{\text { STOP }}$ pin

XOUT pin


Note 1: After warm up is started, when $\overline{\text { STOP }}$ pin input is changed " $L$ " level, STOP mode is not placed.
Note 2: When changing to the level-sensitive release mode from the edge-sensitive release mode, the release mode is not switched until a rising edge of the $\overline{\text { STOP }}$ pin input is detected.

Figure 1.4.9 Level-sensitive Release Mode
b. Edge-sensitive release mode ( $\mathrm{RELM}=0$ )

In this mode, STOP mode is released by a rising edge of the STOP pin input. This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (for example, a clock from a low-power consumption oscillator) is input to the $\overline{\text { STOP }}$ pin.

In the edge-sensitive release mode, STOP mode is started even when the $\overline{\mathrm{STOP}}$ pin input is high.

Example: Starting STOP mode from NORMAL mode
LD (SYSCR1), 10010000B ; Starts after specified to the edge-sensitive mode


Figure 1.4.10 Edge-sensitive Release Mode

STOP mode is released by the following sequence:

1. When returning to NORMAL, clock oscillator is turned on.
2. A warm-up period is inserted to allow oscillation time to stabilize. During warm-up, all internal operations remain halted. Two different warm-up times can be selected with WUT (Bits 2 and 3 in SYSCR1) as determined by the resonator characteristics.
3. When the warm-up time has elapsed, normal operation resumes with the instruction following the STOP mode start instruction (e.g., [SET (SYSCR1). 7]). The start is made after the divider of the timing generator is cleared to " 0 ".

Table 1.4.1 Warm-up Time Example

| WUT | Warm-up Time [ms] |  |  |  |
| :---: | :---: | ---: | ---: | ---: |
|  | Return to NORMAL mode |  |  |  |
|  | DV1CK $=0$ |  | DV1CK $=1$ |  |
| 00 | $3 \times 2^{16} / \mathrm{fc}$ | $(12.29 \mathrm{~m})$ | $3 \times 2^{17} / \mathrm{fc}$ | $(24.58 \mathrm{~m})$ |
| 01 | $2^{16} / \mathrm{fc}$ | $(4.10 \mathrm{~m})$ | $2^{17} / \mathrm{fc}$ | $(8.20 \mathrm{~m})$ |
| 10 | $3 \times 2^{14} / \mathrm{fc}$ | $(3.07 \mathrm{~m})$ | $3 \times 2^{15} / \mathrm{fc}$ | $(6.14 \mathrm{~m})$ |
| 11 | $2^{14} / \mathrm{fc}$ | $(1.02 \mathrm{~m})$ | $2^{15} / \mathrm{fc}$ | $(2.05 \mathrm{~m})$ |

Note: The warm-up time is obtained by dividing the basic clock by the divider: therefore, the warm-up time may include a certain amount of error if there is any fluctuation of the oscillation frequency when STOP mode is released. Thus, the warm-up time must be considered an approximate value.


Figure 1.4.11 STOP Mode Start/Release

STOP mode can also be released by setting the $\overline{\text { RESET }}$ pin low, which immediately performs the normal reset operation.

Note: When STOP mode is released with a low hold voltage, the following cautions must be observed.
The power supply voltage must be at the operating voltage level before releasing STOP mode. The $\overline{R E S E T}$ pin input must also be high, rising together with the power supply voltage. In this case, if an external time constant circuit has been connected, the $\overline{\text { RESET }}$ pin input voltage will increase at a slower rate than the power supply voltage. At this time, there is a danger that a reset may occur if input voltage level of the $\overline{\text { RESET }}$ pin drops below the non-inverting high-level input voltage (hysteresis input).
(2) IDLE mode

IDLE mode is controlled by the system control register 2 and maskable interrupts. The following status is maintained during IDLE mode.

1. Operation of the CPU and watchdog timer is halted. On-chip peripherals continue to operate.
2. The data memory, CPU registers and port output latches are all held in the status in effect before IDLE mode was entered.
3. The program counter holds the address of the instruction following the instruction which started IDLE mode.

Example: Starting IDLE mode.
SET (SYSCR2). $4 \quad ; \quad$ IDLE $\leftarrow 1$


Figure 1.4.12 IDLE Mode

IDLE mode includes a normal release mode and an interrupt release mode. Selection is made with the interrupt master enable flag (IMF). Releasing the IDLE mode returns from IDLE to NORMAL.
a. Normal release mode ( $\mathrm{IMF}=" 0$ ")

IDLE mode is released by any interrupt source enabled by the individual interrupt enable flag (EF) or an external interrupt 0 ( $\overline{\text { INT0 }}$ pin) request. Execution resumes with the instruction following the IDLE mode start instruction (e.g., [SET (SYSCR2).4]). Normally, IL (Interrupt latch) of interrupt source to release IDLE mode must be cleared by load instructions.
b. Interrupt release mode ( $\mathrm{IMF}=" 1$ ")

IDLE mode is released and interrupt processing is started by any interrupt source enabled with the individual interrupt enable flag (EF) or an external interrupt 0 ( $\overline{\mathrm{INTO}} \mathrm{pin}$ ) request. After the interrupt is processed, the execution resumes from the instruction following the instruction which started IDLE mode.

Note: When a watchdog timer interrupt is generated immediately before the IDLE mode is started, the watchdog timer interrupt will be processed but IDLE mode will not be started.


Main
system
clock
Interrupt
request
Program
counter
Instruction
execution
Watchdog
timer
Main
system
clock
Interrupt
request
$\begin{aligned} & \text { Program } \\ & \text { counter } \\ & \text { Instruction } \\ & \text { execution } \\ & \text { Watchdog } \\ & \text { timer }\end{aligned}$
Main
system
clock

Figure 1.4.13 IDLE Mode Start/Release

IDLE mode can also be released by setting the $\overline{\text { RESET }}$ pin low, which immediately performs the reset operation. After reset, the TMP88CS38B/CM38B/CP38B is placed in NORMAL mode.

### 1.5 Interrupt Controller

The TMP88CS38B/CM38B/CP38B has a total of 17 interrupt sources; 6 externals and 11 internals. Multiple interrupts with priorities are also possible. Two of the internal sources are pseudo non-maskable interrupts; the remainder are all maskable interrupts.

Table 1.5.1 Interrupt Sources

| Interrupt Source |  |  | Enable Condition | Interrupt Latch | Vector Table Address | Priority |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Internal/ External | (Reset) |  | Non maskable | - | FFFFCH | High 0 |
| Internal | INTSW | (Software interrupt) | Pseudo non maskable | - | FFFF8H | 1 |
| Internal | INTWDT | (Watchdog timer interrupt) |  | $\mathrm{IL}_{2}$ | FFFF4H | 2 |
| External | INTO | (External interrupt 0) | $\mathrm{IMF} \cdot \mathrm{EF}_{3}=1$, INTOEN = 1 | $\mathrm{IL}_{3}$ | FFFFOH | 3 |
| Internal | INTTC1 | (16-bit TC1 interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{4}=1$ | $\mathrm{IL}_{4}$ | FFFECH | 4 |
| External | INTKWU | (Key-on wakeup) | $\mathrm{IMF} \cdot \mathrm{EF}_{5}=1$ | $\mathrm{IL}_{5}$ | FFFE8H | 5 |
| Internal | INTTBT | (Time base timer interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{6}=1$ | $1 L_{6}$ | FFFE4H | 6 |
| External | INT2 | (External interrupt 2) | $\mathrm{IMF} \cdot \mathrm{EF}_{7}=1$ | $\mathrm{IL}_{7}$ | FFFEOH | 7 |
| Internal | INTTC3 | (8-bit TC3 interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{8}=1$ | $1 L_{8}$ | FFFDCH | 8 |
| Internal | INTTSBI | (SBI interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{9}=1$ | $\mathrm{IL}_{9}$ | FFFD8H | 9 |
| Internal | INTTC4 | (8-bit TC4 interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{10}=1$ | $\mathrm{IL}_{10}$ | FFFD4H | 10 |
| External | INT3 | (External interrupt 3) | $\mathrm{IMF} \cdot \mathrm{EF}_{11}=1$ | $\mathrm{IL}_{11}$ | FFFDOH | 11 |
| External | INT4 | (External interrupt 4) | $\mathrm{IMF} \cdot \mathrm{EF}_{12}=1$ | $\mathrm{IL}_{12}$ | FFFCCH | 12 |
| Internal | INTADC | (AD converter interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{13}=1$ | $\mathrm{IL}_{13}$ | FFFC8H | 13 |
| Internal | INTTC2 | (16-bit TC2 interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{14}=1$ | IL 14 | FFFC4H | 14 |
| External | INT5 | (External interrupt 5) | $\mathrm{IMF} \cdot \mathrm{EF}_{15}=1$ | $\mathrm{IL}_{15}$ | FFFCOH | 15 |
| Internal | INTOSD | (OSD interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{16}=1$ | $\mathrm{IL}_{16}$ | FFFBCH | 16 |
| Internal | INTSLI | (Slicer interrupt) | $\mathrm{IMF} \cdot \mathrm{EF}_{17}=1$ | $\mathrm{IL}_{17}$ | FFFB8H | 17 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{18}=1$ | $\mathrm{IL}_{18}$ | FFFB4H | 18 |
|  |  | Reserved | IMF $\cdot \mathrm{EF}_{19}=1$ | $\mathrm{IL}_{19}$ | FFFBOH | 19 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{20}=1$ | $\mathrm{IL}_{20}$ | FFFACH | 20 |
|  |  | Reserved | $\mathrm{IMF} \cdot \mathrm{EF}_{21}=1$ | $\mathrm{IL}_{21}$ | FFFA8H | 21 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{22}=1$ | $\mathrm{IL}_{22}$ | FFFA4H | 22 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{23}=1$ | $\mathrm{IL}_{23}$ | FFFAOH | 23 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{24}=1$ | $1 \mathrm{~L}_{24}$ | FFF9CH | 24 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{25}=1$ | $\mathrm{IL}_{25}$ | FFF98H | 25 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{26}=1$ | $\mathrm{IL}_{26}$ | FFF94H | 26 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{27}=1$ | $1 \mathrm{~L}_{27}$ | FFF90H | 27 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{28}=1$ | $1 \mathrm{~L}_{28}$ | FFF8CH | 28 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{29}=1$ | $\mathrm{IL}_{29}$ | FFF88H | 29 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{30}=1$ | IL30 | FFF84H | 30 |
| Reserved |  |  | $\mathrm{IMF} \cdot \mathrm{EF}_{31}=1$ | IL31 | FFF80H | Low 31 |

Note: Before you change each enable flag (EF) and/or each interrupt latch (IL), be sure to clear the interrupt master enable flag (IMF) to "0" (to disable interrupts).
a. After a DI instruction is executed.
b. When an interrupt is accepted, IMF is automatically cleared to " 0 ".

However to enable nested interrupts, change EF and/or IL before setting IMF to " 1 " (to enable interrupts).
If the individual enable flags (EF) and interrupt latches (IL) are set under conditions other than the above, the proper operation cannot be guaranteed.


Figure 1.5.1 Interrupt Controller Block Diagram

Interrupt latches (IL) that hold the interrupt requests are provided for interrupt sources. Each interrupt vector is independent.

The interrupt latch is set to " 1 " when an interrupt request is generated, and requests the CPU to accept the interrupt. The acceptance of maskable interrupts can be selectively enabled and disabled by program using the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). When two or more interrupts are generated simultaneously, the interrupt is accepted in the highest priority order as determined by the hardware. Figure 1.5.1 shows the interrupt controller.
(1) Interrupt latches (IL31 to $\mathrm{IL}_{2}$ )

Interrupt latches are provided for each source, except for a software interrupt. The latch is set to " 1 " when an interrupt request is generated, and requests the CPU to accept the interrupt. The latch is cleared to " 0 " just after the interrupt is accepted. All interrupt latches are initialized to "0" during reset.

The interrupt latches are assigned to addresses $0003 \mathrm{CH}, 0003 \mathrm{DH}, 0002 \mathrm{EH}$ and 0002 FH in the SFR. Except for IL2, each latch can be cleared to " 0 " individually by an instruction ; however, the read-modify-write instruction such as bit manipulation or operation instructions cannot be used. When interrupt occurred during order execution, the reason is because interrupt request is cleared. Thus, interrupt requests can be canceled and initialized by the program. Note that request the interrupt latches cannot be set to " 1 " by an instruction. For example, it may be that each latch is cleared even if an interrupt request is generated during instruction exection.
The contents of interrupt latches can be read out by an instruction. Therefore, testing interrupt request by software is possible.

| Example 1: Clears interrupt latches |  |  |
| :---: | :---: | :---: |
| DI | ; | Disable interrupt |
| LDW (ILL), 1110100000111111B |  | $\mathrm{IL}_{12}, \mathrm{IL}_{10}$ to $\mathrm{IL}_{6} \leftarrow 0$ |
| Example 2: Reads interrupt latches |  |  |
| LD WA, (ILL) | , | $\mathrm{W} \leftarrow \mathrm{ILH}, \mathrm{A} \leftarrow \mathrm{ILL}$ |
| Example 3: Tests an interrupt latch |  |  |
| TEST (ILL). 7 | ; | if $\mathrm{IL}_{7}=1$ then jump |
| JR F, SSET |  |  |

(2) Interrupt enable register (EIR)

The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the pseudo non-maskable interrupts (Software and watchdog timer interrupts). Pseudo non-maskable interrupts are accepted regardless of the contents of the EIR; however, the pseudo non-maskable interrupt cannot be nested more than once at the same time.

The EIR consists of an interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). These registers are assigned to addresses 0003AH, 0003BH, 0002CH and 0002 DH in the SFR , and can be read and written by an instruction (including read-modify-write instruction such as bit manipulation instructions).

Note: Do not use the read-modify-write instruction for the EIRL (Address 0003AH) during pseudo non-maskable interrupt service task. If the read-modify-write instruction is used, the IMF is not set to " 1 " after RETN.

1. Interrupt master enable flag (IMF)

The interrupt master enable flag (IMF) enables and disables the acceptance of all maskable interrupts. Clearing this flag to " 0 " disables the acceptance of all maskable interrupts. Setting to " 1 " enables the acceptance of interrupts.
When an interrupt is accepted, this flag is cleared to " 0 " to temporarily disable the acceptance of other maskable interrupts. After execution of the interrupt service program, this flag is set to " 1 " by the maskable interrupt return instruction [RETI] to again enable the acceptance of interrupts. If an interrupt request has already been occurred, interrupt service starts immediately after execution of the [RETI] instruction.

Pseudo non-maskable interrupts are returned by the [RETN] instruction. In this case, the IMF is set to " 1 " only when pseudo non-maskable interrupt service is started with interrupt acceptance enabled (IMF $=1$ ). Note that the IMF remains " 0 " when cleared by the interrupt service program.

The IMF is assigned to bit0 at address 0003AH in the SFR, and can be read and written by an instruction. The IMF is normally set and cleared by the [EI] and [DI] instructions, and the IMF is initialized to " 0 " during reset.
2. Individual interrupt enable flags ( $\mathrm{EF}_{17}$ to $\mathrm{EF}_{3}$ )

These flags enable and disable the acceptance of individual maskable interrupts, except for an external interrupt 0 . Setting the corresponding bit of an individual interrupt enable flag to " 1 " enables acceptance of an interrupt, setting the bit to " 0 " disables acceptance.

Example 1: Sets EF for individual interrupt enable, and sets IMF to " 1 ".

| DI |  | $;$ |
| :--- | :--- | :--- |
| LD | (EIRE), 00000001 B | $; \mathrm{EF}_{16} \leftarrow 1$ |
| LDW | (EIRL), 1110100010100001 B |  |

Example 2: Sets an individual interrupt enable flag to " 1 ".
SET (EIRH). $4 \quad ; \quad E F_{12} \leftarrow 1$


Interrupt Enable Registers (EIR)

| R | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (0002C, | $\mathrm{EF}_{31}: E F_{30}: E F_{29}: \mathrm{EF}_{28}: \mathrm{EF}_{27}: \mathrm{EF}_{26}: E F_{25}: E F_{24}$ |  |  |  |  |  |  |  | $\mathrm{EF}_{23}: E F_{22}: E F_{21}: E F_{20}: E F_{19}: E F_{18}: E F_{17}: E F_{16}$ |  |  |  |  |  |  |  |
| 0002DH) | EIR ${ }_{\text {D }}$ (0002DH) |  |  |  |  |  |  |  | $\operatorname{EIR}_{\mathrm{E}}(0002 \mathrm{CH})$ |  |  |  |  |  |  |  |
| $\begin{gathered} \text { EIR } \\ \text { (0003A, } \end{gathered}$ | $E F_{15} ; E F_{14} / \mathrm{EF}_{13} / \mathrm{EF}_{12}: E F_{11} / \mathrm{EF}_{10}: E F_{9}: E F_{8}$ |  |  |  |  |  |  |  | $\mathrm{EF}_{7}: \mathrm{EF}_{6}: \mathrm{EF}_{5}: \mathrm{EF}_{4}: \mathrm{EF}_{3}$ |  |  |  |  |  |  | IMF |
| 0003BH) | $\mathrm{EIR}_{\mathrm{H}}(0003 \mathrm{BH})$ |  |  |  |  |  |  |  | $\operatorname{EIR}_{L}(0003 \mathrm{AH})$ |  |  |  |  |  |  |  |

Note 1: Do not clear IL with read-modify-write instructions such as bit operations.
Note 2: Do not set IMF to "1" during non-maskable interrupt service program.
Note 3: Bits 1 and 0 in $I L_{L}$ are read in as undefined data when a read instruction is executed.
Note 4: *: Don't care
Note 5: Do not clear IL 2 to " 0 " by an instruction.
Note 6: At TMP88CS38/CM38A/CP38A, $\mathrm{IL}_{18}$ to $\mathrm{IL}_{31}$ and $\mathrm{EF}_{18}$ to $\mathrm{EF}_{31}$ are not used.
Note 7: After IMF is cleared, modify EF and IL.

Figure 1.5.2 Interrupt Latches (IL) and Interrupt Enable Registers (EIR)

### 1.5.1 Interrupt Sequence

An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to " 0 " by a reset or an instruction. Interrupt acceptance sequence requires 12 machine cycles ( $3 \mu \mathrm{~s}$ at $\mathrm{fc}=16 \mathrm{MHz}$ in the NORMAL mode) after the completion of the current instruction execution. The interrupt service task terminates upon execution of an interrupt return instruction [RETI] (for maskable interrupts) or [RETN] (for pseudo non-maskable interrupts). Figure 1.5 .3 shows the timing chart of interrupt acceptance processing.
(1) Interrupt acceptance

Interrupt acceptance processing is as follows.

1. The interrupt master enable flag (IMF) is cleared to " 0 " to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled.
2. The interrupt latch (IL) for the interrupt source accepted is cleared to " 0 ".
3. The contents of the program counter (PC) and the program status word (PSW) are saved (Pushed) on the stack in sequence of $\mathrm{PSW}_{\mathrm{H}}, \mathrm{PSW}_{\mathrm{L}}, \mathrm{PCE}_{\mathrm{E}}, \mathrm{PC}_{\mathrm{H}}, \mathrm{PC}_{\mathrm{L}}$. The stack pointer (SP) is decremented five times.
4. The entry address of the interrupt service program is read from the vector table, and set to the program counter.
5. The RBS control code is read from the vector table. The lower 4 bits of this code is added to the RBS.
6. The instruction stored at the entry address of the interrupt service program is executed.

Example: Correspondence between vector table address for INTTBT and the entry address of the interrupt service program.


A maskable interrupt is not accepted until the IMF is set to " 1 " even if the maskable interrupt higher than the level of current servicing interrupt is occurred.

When nested interrupt service is necessary, the IMF is set to " 1 " in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags.

Note: Do not use the read-modify-write instruction for the EIRL (Address 0003AH) during pseudo non-maskable interrupt service task.

(a) Interrupt acceptance

(b) Return from interrupt instruction

Note 1: a: Return address, b: Entry address, c: Address which the RETI instruction is stored
Note 2: The maximum response time from when an IL is set until an interrupt acceptance processing starts is $62 / \mathrm{fc}$ [s] with interrupt enabled.

Figure 1.5.3 Timing Chart of Interrupt Acceptance and Interrupt Return Instruction
(2) Saving/restoring general-purpose registers

During interrupt acceptance processing, the program counter (PC) and the program status word (PSW) are automatically saved on the stack, but not the accumulator and other registers. These registers are saved by the program if necessary. Also, when nesting multiple interrupt services, it is necessary to avoid using the same data memory area for saving registers.

The following method is used to save/restore the general-purpose registers.

1. General-purpose register save/restore by automatic register bank changeover

The general-purpose registers can be saved at high speed by switching to a register bank that is not in use. Normally, the bank0 is used for the main task and the banks 1 to 15 are assigned to interrupt service tasks. To increase the efficiency of data memory utilization, the same bank is assigned for interrupt sources which are not nested.

The switched bank is automatically restored by executing an interrupt return instruction [RETI] or [RETN]. Therefore, it is not necessary for a program to save the RBS.

```
Example: Register bank changeover
MINTxx: % Interrupt processing
                        \vdots
VINTxx: DP PINTxx
    DB 1 ; RBS }\leftarrow\textrm{RBS}+
```

2. General-purpose register save/restore by register bank changeover

The general-purpose registers can be saved at high speed by switching to a register bank that is not in use. Normally, the bank0 is used for the main tank and the banks 1 to 15 are assigned to interrupt service tasks.


Figure 1.5.4 Saving/Restoring General-purpose Registers
3. General-purpose registers save/restore using push and pop instructions

To save only a specific register, and when the same interrupt source occurs more than once, the general-purpose registers can be saved/restored using the push/pop instructions.

Example: Register save/restore using push and pop instructions

| PINTxx: | PUSH | WA | Save WA register pair |
| :---: | :---: | :---: | :---: |
|  | Interru | cessi |  |
|  | POP | WA | Restore WA register pair |
|  | RETI |  | Return |


4. General-purpose registers save/restore using data transfer instructions

Data transfer instruction can be used to save only a specific general-purpose register during processing of single interrupt.

Example: Saving/restoring a register using data transfer instructions PINTxx:


Save A register

Restore A register
Return
(3) Interrupt return

The interrupt return instructions [RETI]/[RETN] perform the following operations.

| [RETI] Maskable Interrupt Return | [RETN] Non-maskable Interrupt Return |
| :--- | :--- |
| 1. The contents of the program counter and <br> the program status word are restored <br> from the stack. | 1. The contents of the program counter and program status <br> word are restored from the stack. |
| 2. The stack pointer is incremented 5 times. <br> 3. The interrupt master enable flag is set to <br> "1". | 2. The stack pointer is incremented 5 times. <br> 3. The interrupt master enable flag is set to "1" only when a <br> non-maskable interrupt is accepted in interrupt enable status. <br> However, the interrupt master enable flag remains at " 0 " <br> when so clear by an interrupt service program. |
| 4. The interrupt nesting counter is <br> decremented, and the interrupt nesting <br> flag is changed. | 4.The interrupt nesting counter is decremented, and the <br> interrupt nesting flag is changed. |

Interrupt requests are sampled during the final cycle of the instruction being executed. Thus, the next interrupt can be accepted immediately after the interrupt return instruction is executed.

Note: When the interrupt processing time is longer than the interrupt request generation time, the interrupt service task is performed but not the main task.

### 1.5.2 Software Interrupt (INTSW)

Executing the [SWI] instruction generates a software interrupt and immediately starts interrupt processing (INTSW is highest prioritized interrupt). However, if processing of a non-maskable interrupt is already underway, executing the SWI instruction will not generate a software interrupt but will result in the same operation as the [NOP] instruction.

Use the [SWI] instruction only for detection of the address error or for debugging.

1. Address error detection

FFH is read if for some cause such as noise the CPU attempts to fetch an instruction from a non-existent memory address. Code FFH is the SWI instruction, so a software interrupt is generated and an address error is detected. The address error detection range can be further expanded by writing FFH to unused areas of the program memory. Address-trap reset is generated in case that an instruction is fetched from RAM, SFR or DBR areas.
2. Debugging

Debugging efficiency can be increased by placing the SWI instruction at the software break point setting address.

### 1.5.3 External Interrupts

The TMP88CS38B/CM38B/CP38B each have five external interrupt inputs ( $\overline{\mathrm{INT}}$, INT2, INT3, INT4 and $\overline{\text { INT5 }}$ ). Three of these are equipped with digital noise rejection circuits (Pulse inputs of less than a certain time are eliminated as noise). Edge selection is also possible with INT2, INT3 and INT4.

The $\overline{\mathrm{INTO}} / \mathrm{P} 50$ pin can be configured as either an external interrupt input pin or an input/output port, and is configured as an input port during reset.

Edge selection, noise rejection control except INT3 pin input and $\overline{\mathrm{INT0}} / \mathrm{P} 50$ pin function selection are performed by the external interrupt control register (EINTCR). Edge selecting and noise rejection control for INT3 pin input are preformed by the remote control signal preprocessor control registers. (Refer to the section of the remote control signal preprocessor.) When INT0EN $=0$, the IL3 will not be set even if the falling edge of $\overline{\text { INT0 }}$ pin input is detected.

Table 1.5.2 External Interrupts

| Source | Pin | Secondary Function Pin | Enable Conditions | Edge | Digital Noise Rejection |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INTO | $\overline{\text { into }}$ | P50/TC2/ $\overline{\text { PWM }}$ | $\mathrm{IMF}=1, \mathrm{INTOEN}=1, \mathrm{EF}_{3}=1$ | Falling edge | Any pulse shorter than 2/fc [s] is regarded as noise and removed. Pulses not shorter than 7/fc [s] are definitely regarded as signals. |
| INT2 | INT2 | $\begin{aligned} & \mathrm{P} 53 / \mathrm{TC} 1 / \overline{\mathrm{SCK}} 1 / \\ & \text { AINO/KWU0 } \end{aligned}$ | $\mathrm{IMF} \cdot \mathrm{EF}_{7}=1$ | Falling edge or rising edge | Pulses of less than 7/fc [s] are eliminated as noise. Pulses equal to or more than $25 / \mathrm{fc}$ [s] are regarded as signals. |
| INT3 | INT3 | P30/RXIN | $\mathrm{IMF} \cdot \mathrm{EF}_{11}=1$ | Falling edge, rising edge or falling/rising edge | Refer to the section of the remote control preprocessor |
| INT4 | INT4 | P31/TC3 | $\mathrm{IMF} \cdot \mathrm{EF}_{12}=1$ | Falling edge or rising edge | Pulses of less than 7/fc [s] are eliminated as noise. Pulses of 25/fc [s] or more are considered to be signals. |
| INT5 | $\overline{\text { NTS }}$ | P20/ $\overline{\text { STOP }}$ | $\mathrm{IMF} \cdot \mathrm{EF}_{15}=1$ | Falling edge | Any pulse shorter than 2/fc [s] is regarded as noise and removed. Pulses not shorter than 7/fc [s] are definitely regarded as signals. |

Note 1: The noise rejection function is also affected for timer counter input 1 (TC1 pin).
Note 2: If a noiseless signal is input to the external interrupt pin in the NORMAL or IDLE mode, the maximum time from the edge of input signal until the IL is set is as follows:
(1) INT2, INT4 pin 31/fc [s]
(2) INT3 pin Refer to the section of the remote control preprocessor.

Note 3: If a dual-function pin is used as an output port, changing data or switching between input and output generates a pseudo interrupt request signal. To ignore this signal, it is necessary to reset the interrupt enable flag.

Note 4: If INTOEN $=$ " 0 ", detecting the falling edge of the $\overline{\mathrm{INTO}}$ pin input does not set the interrupt latch IL3.


Note 1: fc: High-frequency clock [Hz], *: Don't care
Note 2: Edge detection during switching edge selection is invalid.
Note 3: Do not change EINTCR only when IMF = 1. After changing EINTCR, interrupt latches of external interrupt inputs must be cleared to " 0 " using load instruction.

Note 4: In order to change of external interrupt input by rewriting the contents of INT2ES and INT4ES during NORMAL mode, clear interrupt latches of external interrupt inputs (INT2 and INT4) after 8 machine cycles from the time of rewriting.

Note 5: In order to change an edge of timer counter input by rewritng the contents of INT2ES during NORMAL mode, rewrite the contents after timer counter is stopped $(T C * S=0)$, that is, terrupt disable state.
Then, clear a interrupt latch of external interrupt input (INT2) after 8 machine cycles from the time of rewriting to change to interrupt enable state. Finally, start timer counter.
Example: When change TC1 pin inputs edge in external trigger timer mode from rising edge falling edge.

| LD (TC1CR) , 01001000B | $;$ | TC1S $\leftarrow 00$ (Stops TC1) |
| :--- | :--- | :--- |
| DI | $;$ | IMF $\leftarrow 0$ (Disables interrupt service) |
| LD (EINTCR) , 00000100B | $;$ | INT2ES $\leftarrow 1$ (Change edge selection) |
| NOP |  |  |
| to |  |  |
| NOP | $;$ | IL7 $\leftarrow 0$ (Clears interrupt latch) |
| LD (ILL) , 01111111B | $;$ | IMF $\leftarrow 1$ (Enable interrupt service) |
| EI | TD (TC1CR) , 01111000B | $;$ |

Figure 1.5.5 External Interrupt Control Register

### 1.6 Reset Circuit

The TMP88CS38B/CM38B/CP38B has four types of reset generation procedures: An external reset input, an address trap reset output, a watchdog timer reset output and a system clock reset output. Table 1.6 .1 shows on-chip hardware initialization by reset action.

The malfunction reset output circuit such as watchdog timer reset, address trap reset and system clock reset is not initialized when power is turned on. The $\overline{\text { RESET }}$ pin can output level " L " at the maximum $24 / \mathrm{fc}$ [s] ( $1.5 \mu \mathrm{~s}$ at 16 MHz ) when power is turned on.

Table 1.6.1 Initializing Internal Status by Reset Action

| On-chip Hardware | Initial Value | On-chip Hardware | Initial Value |
| :---: | :---: | :---: | :---: |
| Program counter (PC) | (FFFFEH to FFFFCH) | Prescaler and divider of timing generator | 0 |
| Stack pointer (SP) | Not initialized |  |  |
| General-purpose registers (W, A, B, C, D, E, H, L) | Not initialized |  |  |
| Register bank selector (RBS) | 0 | Watchdog timer | Enable |
| Jump status flag (JF) | 1 |  |  |
| Zero flag (ZF) | Not initialized | Output latches of I/O ports | Refer to I/O port circuitry |
| Carry flag (CF) | Not initialized |  |  |
| Half carry flag (HF) | Not initialized |  |  |
| Sign flag (SF) | Not initialized |  |  |
| Overflow flag (VF) | Not initialized |  |  |
| Interrupt master enable flag (IMF) | 0 |  |  |
| Interrupt individual enable flags (EF) | 0 | Control registers | Refer to each of control register |
| Interrupt latches (IL) | 0 |  |  |
| - | - | RAM | Not initialized |

### 1.6.1 External Reset Input

The $\overline{\operatorname{RESET}}$ pin contains a Schmitt trigger (Hysteresis) with an internal pull-up resistor. When the $\overline{R E S E T}$ pin is held at "L" level for at least 3 machine cycles ( $12 / \mathrm{fc}[\mathrm{s}]$ ) with the power supply voltage within the operating voltage range and oscillation stable, a reset is applied and the internal state is initialized.

When the $\overline{\text { RESET }}$ pin input goes high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFFCH to FFFFEH.


Figure 1.6.1 Reset Circuit

### 1.6.2 Address-trap-reset

If the CPU should start looping for some cause such as noise and an attempt be made to fetch an instruction from the on-chip RAM, DBR or the SFR area, address-trap-reset will be generated. Then, the $\overline{\text { RESET }}$ pin output will go low. The reset time is about $8 / \mathrm{fc}$ to $24 / \mathrm{fc}$ [s] ( 0.5 to $1.5 \mu \mathrm{~s}$ at 16 MHz ).


Note 1: $0 \leq \mathrm{a} \leq 008 \mathrm{BFH}$ (TMP88CS38B), $0 \leq \mathrm{a} \leq 006 \mathrm{BFH}$ (TMP88CM38B/CP38B) $0 \leq \mathrm{a} \leq 002 \mathrm{BFH}$ (The ROM corrective function is enabled.)

Note 2: During reset release, reset vector " $r$ " is read out, and an instruction at address " $r$ " is fetched and decoded.

Figure 1.6.2 Address-trap-reset

### 1.6.3 Watchdog Timer Reset

Refer to section 2.4 "Watchdog Timer".

### 1.6.4 System-clock-reset

Clearing bits 7 in SYSCR2 to " 0 ", system clock stops and causes the microcomputer to deadlock. This can be prevented by automatically generating a reset signal whenever bits 7, 6 and 5 in SYSCR2 $=000$ is detected to continue the oscillation. The $\overline{\text { RESET }}$ pin output goes low from high-impedance. The reset time is about $8 / \mathrm{fc}$ to $24 / \mathrm{fc}$ [s] ( 0.5 to $1.5 \mu \mathrm{~s}$ at 16 MHz).

### 1.7 ROM Corrective Function

The ROM corrective function can patch the part (s) of on-chip ROM with some bugs.
The ROM corrective function have two modes. One is to replaced the instruction on a certain address in the ROM with the jump instruction to branch into the RAM area where the patched codes (Program jump mode). The other is to replace a byte or a word ( 2 or 3 bytes) length data in the ROM with the patched data (Data replacement mode). Four independent location can be patched.

Note 1: When use ROM corrective circuit, it is necessary to contain a program which operates to load patched program and/or replacement data from external memory into an internal data RAM in an initial routine.

Note 2: The address of a instruction for IDLE mode can not be specificated as start address of corrective area.

Note 3: The BM88CS38N0A does not support the ROM corrective circuit. Use the TMP88PS38B to debug a program of this circuit. In this case, note the following.
In program jump mode, jump target addresses that can be specified with the TMP88CM38B/CP38B ( 002 COH to 006BFH) are different from those that can be specified with the TMP88PS38B ( 002 COH to 008BFH). Therefore, if a jump target address is within a range of 006 COH to 008 BFH , it is necessary to change this addresse and also addresses for loading a patch program.

Example:


### 1.7.1 Configuration



Figure 1.7.1 ROM Corrective Circuit

### 1.7.2 Control

The ROM corrective function is controlled by ROM corrective control register (ROMCCR) and ROM corrective data register (ROMCDR).


Figure 1.7.2 ROM Corrective Control Register, Status Register and ROM Corrective Data Register
(1) Enable and disable

The ROM corrective function is disabled after releasing reset. It is enabled after setting the data for one bank into ROMCDR. And the address-trap-reset is not generated when fetching an instruction from the RAM area except the address 02 C 0 H to 08 BFH .

After the ROM corrective function is enabled, it is necessary to reset the microcontroller in order to disable it.
(2) Data replacement mode

The ROM corrective function has the program jump mode and the data replacement mode.

By setting CMx (x: 0 to 3 ) in ROMCCR, the data replacement mode is selected.
(3) The ROM corrective data register writing

The ROM corrective data register has four banks corresponding to four independent locations to patch. The write data counter (WDC) points each bank set. (Figure 1.7.2)


Figure 1.7.3 Banks and WDC Value of the Program Corrective Data Register

Whenever ROMCDR is written, WDC is incremented to indicate what data is writen via ROMCDR. During reset, WDC is initialized to " 0 ".
(1) The lower start address of the corrective area (8 bits)
(2) The middle start address of the corrective area (8 bits)
(3) The upper start address of the corrective area (4 bits)
(4) The lower jump address/replacement data (8 bits)
(5) The middle jump address/replacement data (8 bits)
(6) The upper jump address (4 bits)/replacement data

Note 1: Corrective addresses must have over five addresses each other.
Note 2: The address of a instruction for IDLE mode can not be specificated as start address of corrective area.

### 1.7.3 Functions

The ROM corrective function can correct maximum four ROM areas with their corresponding four banks of ROM corrective registers. Either program jump mode or data replacement mode is selected for each bank by CM0 to CM3 respectively.
(1) Program jump mode

In the program jump mode, the system executes a jump instruction when the program execution reaches the instruction at the corrective ROM address, skips from the instruction which would have been executed, and executes an instruction at a preset jump address.
Clearing ROMCCR CMx (x: 0 to 3 ) to "0" puts the system in the program jump mode. Use ROMCDR to set the corrective ROM address and jump address.
When the start address of an erroneous program is a corrective ROM address, and that of the patch program is a jump address, the bug in the erroneous program can be fixed. Note that the patch program should end with a jump instruction, which causes a return to the built-in ROM.

Note: For program jump mode, the address to be corrected must be the start address of the instruction.

Example 1: Setting the program correction circuit with the initial routine
Using the initial routine program, which is executed right after reset, set the program correction circuit's register and stores the patch program into the built-in RAM as follows.

1. Read the flag, which indicates whether to use the program correction circuit, from the external memory.
2. If that circuit is not used, perform normal initial processing.
3. If it is used, clear CMx to 0 to establish the program jump mode.
4. Read the corrective ROM address and jump address from the external memory.
5. Set the corrective ROM address and jump address, which were read in step " 4. ., in ROMCDR.
6. Read the number of bytes for the patch program from the external memory.
7. Read the program with a number of bytes, equal to the byte count read in step " 6 .", from the external memory, and store that program into the built-in RAM.
8. Repeat steps " 4 ." through " 7 ." as many times as there are required banks.

Example 2: There is bugs on the locations from 0 C 020 H to 0 C 085 H
The corrective address, the jump vector, the program patch codes and other information to patch the ROM with the bugs must be read out from any of memory storage that holds them during initial program routine. $\mathrm{CMn}=0$ specifies the program jump mode. Subsequently, the patch program codes are loaded into RAM ( 00600 H to 006 EFH ). The start address $(0 \mathrm{C} 020 \mathrm{H})$ of the ROM necessary to patch is written to the corrective ROM address registers, and the start address ( 00600 H ) of the RAM area to patch is loaded onto the jump address registers. When the instruction at 0 C 020 H is fetched, the instruction to jump into 00600 H is unconditionally executed instead of the instruction at 0 C 020 H , and the subsequent patch program codes are executed. The jump instruction at the end of the patch program codes returns to the ROM at 0 C 086 H .


Note: Corrective address must be assigned to 1st byte of instruction codes on the program jump mode.
(2) Data replacement mode

In the data replacement mode, the system replaces reference data stored in the ROM area with the new instead of correcting the data reference instruction when that reference data is changed.

The program jump mode reduces the complexity of correcting the processing routine. However, when this mode is used, if there is a need to replace only the fixed data in ROM, the instruction to reference this ROM data should be corrected. Thus, a large amount of ROM is required for the patch program. To avoid this, the system has the data replacement mode. With this mode, three consecutive bytes of data can be replaced for each bank. (For an instruction which accesses only one byte, only the first byte can be replaced. For an instruction which accesses only two bytes, the two consecutive bytes can be replaced.) Setting ROMCCR CMx (x: 0 to 3) to " 1 " puts the system in the data replacement mode. Specify the start address of ROM data to be replaced as the corrective ROM address. Then, specify the new three-byte data as the patch data.

Note: For data replacement mode, the corrective address should be the address of fixed data (including a vector). (The operation code and operand cannot be changed.)

Example 1: Setting the program correction circuit with the initial routine
Using the initial routine program, which is executed right after reset, set the program correction circuit's register as follows.

1. Read the flag, which indicates whether to use the program correction circuit, from the external memory.
2. If that circuit is not used, perform normal initial processing.
3. If it is used, set CMx to " 1 " to establish the data replacement mode.
4. Read the address of the data to be replaced and the patch data from the external memory.
5. Set the address and patch data, which were read in step " 4 .", in ROMCDR.
6. Repeat steps " 4 ." and " 5 ." as many times as there are required banks.

Example 2: Replacing data 55 H at 0 C 020 H with 33 H
Using the initial routine program, which is executed right after reset, read the start address of the data to be replaced and the patch data from the external memory. Set CMx (x: 0 to 3) to " 1 " to change the correction mode to the data replacement mode. Specify the start address ( 0 C 020 H ) of the data to be replaced as the corrective ROM address. Then, specify the new three-byte data ( 33 H for $0 \mathrm{C} 020 \mathrm{H}, \mathrm{CCH}$ for 0 C 021 H , and C 3 H for 0 C 022 H ) as the patch data.


1. At $\mathrm{HL}=0 \mathrm{CO2OH}$, Executing LD A, (HL) loads 33 H in A. (Data replacement)
2. At $\mathrm{HL}=0 \mathrm{C} 021 \mathrm{H}$, Executing LD $A,(\mathrm{HL})$ loads $A A H$ in $A$. (No data replacement)
3. At $\mathrm{HL}=0 \mathrm{CO} 2 \mathrm{H}$, Executing LD WA, (HL) loads CC33H in WA. (Data replacement)
4. At $\mathrm{HL}=0 \mathrm{CO} 20 \mathrm{H}$, Executing LD IX, (HL) loads CCC33H in IX. (Data replacement)

Note 1: Corrective address must be assigned to constant data area on the data replacement mode. (Ope-code and ope-rand can't be replaced by ROM correction circuit.)

Note 2: Instructions which includes "(HL+)" or "(-HL) " operation can't be replaced by ROM corrective circuit on the data replacement mode.

## 2. On-chip Peripheral Functions

### 2.1 Special Function Registers (SFR) and Data Buffer Registers (DBR)

The TLCS-870/X series uses the memory mapped I/O system and all peripheral control and data transfers are performed through the special function registers (SFRs) and data buffer registers (DBR).

The SFR are mapped to addresses 00000 H to 0003 FH , and DBR are mapped to address 00 F 80 H to 00FFFH.

Figure 2.1.1 shows the list of the TMP88CS38B/CM38B/CP38B SFRs and-DBRs.


Figure 2.1.1 (a) SFR

(b) Data buffer registers

Note 1: Do not access reserved areas by the program.
Note 2: -: Cannot be accessed.
Note 3: Write-only registers cannot use the read-modify-write instructions (Bit manipulation instructions such as SET, CLR, etc. and logical operation instructions such as AND, OR, etc.).

Figure 2.1.2 (b) DBR

### 2.2 I/O Ports

The TMP88CS38B/CM38B/CP38B has 6 parallel input/output ports (33 pins) as follows:

|  | Primary Function | Secondary Functions |
| :--- | :--- | :--- |
| Port P2 | 1-bit I/O port | External interrupt input, and STOP mode release signal input |
| Port P3 | 6-bit I/O port | External interrupt input, remote control signal input, data slicer analog <br> input, timer/counter input, serial bus interface input/output and data <br> slicer input |
| Port P4 | 8-bit I/O port | Pulse width modulation output |
| Port P5 | 8-bit I/O port | Pulse width modulation output external interrupt input, timer/counter <br> input, key-on wakeup input, serial bus interface input/output, analog <br> input and I output from OSD circuitry. |
| Port P6 | 8-bit I/O port | R, G, B and Y/BL output from OSD circuitry, R.G.B and Y/BL input, <br> analog input, test video signal output and key-on wakeup input |
| Port P7 | 2-bit I/O port | Horizontal synchronous pulse input and vertical synchronous pulse <br> input to OSD circuitry |

Each output port contains a latch, which holds the output data. All input ports do not have latches, so the external input data should either be held externally until read or reading should be performed several times before processing. Figure 2.2 .1 shows input/output timing examples. External data is read from an I/O port in the S1 state of the read cycle during execution of the read instruction. This timing can not be recognized from outside, so that transient input such as chattering must be processed by the program. Output data changes in the S 2 state of the write cycle during execution of the instruction which writes to an I/O port.


Note: The positions of the read and write cycles may vary, dispending on the instruction.

Figure 2.2.1 Input/Output Timing (Example)

When reading an I/O port except programmable I/O ports, whether the pin input data or the output latch contents are read depends on the instructions, as shown below:
(1) Instructions that read the output latch contents

1. XCH r , (src)
2. SET/CLR/CPL (src).b
3. SET/CLR/CPL (pp).g
4. LD (src).b, CF
5. LD (pp).b, CF
6. ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), n
7. (src) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)
(2) Instructions that read the pin input data
8. Instructions other than the above (1)
9. (HL) side of ADD/ADDC/SUB/SUBB/AND/OR/XOR (src), (HL)

### 2.2.1 Port P2 (P20)

Port P2 is a 1bit input/output port. It is also used as an external interrupt input, and a STOP mode release signal input. When used as an input port, or a secondary function pin, the output latch should be set to " 1 ". During reset, the output latch is initialized to " 1 ".

It is recommended that pin P20 should be used as an external interrupt input, a STOP mode release signal input, or an input port. If used as an output port, the interrupt latch is set on the falling edge of the P20 output pulse.

When a read instruction for port P2 is executed, bits 7 to 1 in P2 are read in as undefined data.


Figure 2.2.2 Port P2

### 2.2.2 Port P3 (P35 to P30)

Port P3 is an 6-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P3 input/output control register 1 (P3CR1). Port P3 is configured as an input if its corresponding P3CR1 bit is cleared to " 0 ", and as an output if its corresponding P3CR1 bit is set to " 1 ". During reset, P3CR1 is initialized to " 0 ", which configures port P3 as an input. The P3 output latches are also initialized to " 1 ". Data is written into the output latch regardless of the P3CR1 contents. Therefore initial output data should be written into the output latch before setting P3CR1.

Port P3 is also used as an external interrupt input, remote-control signal input a timer/counter input, data slicer input and serial bus interface input/output. When used as a secondary function input pin except $\mathrm{I}^{2} \mathrm{C}$ bus interface input/output, the input pins should be set to the input mode. When used as a secondary function output pin except $\mathrm{I}^{2} \mathrm{C}$ bus interface input/output, the output pins should be set to the output mode and beforehand the output latch should be set to " 1 ". When P34 and P35 are used as $\mathrm{I}^{2} \mathrm{C}$ bus interface input/output, P3CR2 bits should be set to the sink open-drain mode, the output latches should be set to " 1 ", and the output pins should be set to the output mode.

Note: Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.

Example 1: Outputs an immediate data $5 A_{H}$ to port P3
LD (P3), $5 \mathrm{~A}_{H} \quad ; \quad \mathrm{P} 3 \leftarrow 5 \mathrm{~A}_{H}$
Example 2: Inverts the output of the lower 4 bits (P33 to P30) in port P3
XOR (P3), 00001111B ; P33 to P30 $\leftarrow \overline{\mathrm{P} 33}$ to $\overline{\mathrm{P} 30}$


Figure 2.2.3 Port P3 and P3CR

### 2.2.3 Port P4 (P47 to P40)

Port P4 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P4 input/output control register (P4CR). Port P4 is configured as an input if its corresponding P4CR bit is cleared to " 0 ", and as an output if its corresponding P4CR bit is set to " 1 ". During reset, P4CR is initialized to " 0 ", which configures port P4 as an input. The P4 output latches are also initialized to " 1 ". Data is written into the output latch regardless of the P4CR contents. Therefore initial output data should be written into the output latch before setting P4CR.
Port P4 is also used as a pulse width modulation (PWM) output. When used as a PWM output pin, the output pins should be set to the output mode and beforehand the output latch should be set to " 1 ".

Note: Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.


Figure 2.2.4 Port P4 and P4CR

### 2.2.4 Port P5 (P57 to P50)

Port P5 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is specified by the corresponding bit in the port P5 input/output control register 1 (P5CR1). Port P5 is configured as an input if its corresponding P5CR1 bit is cleared to " 0 ", and as an output if its corresponding P5CR1 bit is set to " 1 ". During reset, P5CR1 is initialized to " 0 ", which configures port P5 as an input. The P5 output latches are also initialized to " 1 ". Data is written into the output latch regardless of the P5CR1 contents. Therefore initial output data should be written into the output latch before setting P5CR1.
Port P5 is also used as is also used as AD converter analog input, a pulse width modulation (PWM) output external interrupt input, timer/counter input, serial bus interface input/output, and an on screen display (OSD) output (I signal). When used as a secondary function input pin except $\mathrm{I}^{2} \mathrm{C}$ bus interface input/output, the input pins should be set to the input mode. When used as a secondary function output pin except $\mathrm{I}^{2} \mathrm{C}$ bus interface input/output, the output pins should be set to the output mode and beforehand the output latch should be set to " 1 ". When P52 and P51 are used as I ${ }^{2} \mathrm{C}$ bus interface input/output, P5CR2 bits should be set to the sink open-drain mode, the output latches should be set to " 1 ", and the output pins should be set to the output mode. When P57 is used as an OSD output pin, the output pin should be set to the output mode and beforehand the port 6 data selection register (PIDS) should be clear to " 0 ". When used as port P5, the port 6 data selection register (PIDS) should be set to " 1 ".
Note: Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.


Figure 2.2.5 Ports P5

### 2.2.5 Port P6 (P67 to P60)

Port P6 is an 8-bit input/output port which can be configured as an input or an output in one-bit unit under software control. Input/output mode is selected by the corresponding bit in the port P6 input/output control register (P6CR). Port P6 is configured as an input if its corresponding P6CR bit is cleared to " 0 ", and as an output if its corresponding P6CR bit is set to " 1 " and P6nS bit is set to " 1 ". P63 to P60 are sink open-drain ports. During reset, P6CR is initialized to " 0 ", which configures port P6 as an input. The P6 output latches are also initialized to " 1 ".

Data is written into the output latch regardless of the P6CR contents. Therefore initial output data should be written into the output latch before setting P6CR.

Port P6 is used as an on screen display (OSD) output (R, G, B and Y/BL signal)/input (RIN, GIN BIN, Y/BLIN signal), a test video signal output and AD converter analog input. When used as a test video signal output pin, the output pins should be set to the output mode and beforehand the signal control register (SGEN) should be set to " 1 ". When used as a secondary function input, the input pins should be set to the input mode. When used as an OSD output pin, the output pins should be set to the output mode and beforehand the port P6 data selection register (P67S to P64S) should be clear to "0". When used as port P6, the signal control register (P67 to P64) should be set to " 1 ".

Note: Input mode port is read the state of input pin. When input/output mode is used mixed, the contents of output latch setting input mode may be changed by executing bit manipulation instructions.

Example: Sets the lower 4 bits ( P 63 to P 60 ) in port P 6 to the output mode, and the other bit to the input mode.
LD (P6CR), 0FH ; P6CR $\leftarrow 00001111 B$


Figure 2.2.6 Ports P6, P6CR, and P67S to P64S

### 2.2.6 Port P7 (P71 to P70)

Port P7 is a 2bit input/output port, and is also used as a vertical synchronous signal ( $\overline{\mathrm{VD}}$ ) input and a horizontal synchronous signal ( $\overline{\mathrm{HD}}$ ) input for the on screen display (OSD) circuitry.
The output latches, are initialized to " 1 " during reset. When used as an input port or a secondary function pin, the output latch should be set to " 1 ".

When a read instruction for port P7 is executed, bits 7 to 2 in P7 are read in as undefined data.


Figure 2.2.7 Ports P7

### 2.3 Time Base Timer (TBT)

The time base timer generates time base for key scanning, dynamic displaying, etc. It also provides a time base timer interrupt (INTTBT). The time base timer is controlled by a control register (TBTCR) shown in Figure 2.3.1.

An INTTBT is generated on the first falling edge of source clock (the divider output of the timing generator) after the time base timer has been enabled. The divider is not cleared by the program; therefore, only the first interrupt may be generated ahead of the set interrupt period.

The interrupt frequency (TBTCK) must be selected with the time base timer disabled (When the time base timer is changed from enabling to disabling, the interrupt frequency can't be changed.)

Both frequency selection and enabling can be performed simultaneously.

| Example: | Sets the time base timer frequency to $\mathrm{fc} / 2^{16}[\mathrm{~Hz}]$ and enables an |  |  |
| ---: | :--- | ---: | :--- |
| LD | (TBTCR), 00000010B | $;$ | TBTCK $=" 010 "$ |
| LD | (TBTCR), 00001010B | $;$ | TBTEN $=" 1 "$ |
| SET | (EIRL). 6 |  |  |


(a) Configuration
(b) Time base timer interrupt

Figure 2.3.1 Time Base Timer


| TBTEN | Time base timer enable/disable | 0: Disable <br> 1: Enable |  |  | Write only |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TBTCK | Time base timer interrupt frequency select |  | NORMAL, IDLE mode |  |  |
|  |  |  | DV1CK = 0 | DV1CK = 1 |  |
|  |  | 000 | $\mathrm{fc} / 2^{23}[\mathrm{~Hz}]$ | $\begin{aligned} & \mathrm{fc} / 2^{24}[\mathrm{~Hz}] \\ & \mathrm{fc}^{22} / \mathrm{P}^{22} \end{aligned}$ |  |
|  |  | 001 | fc/2 | fc/2 ${ }^{22}$ |  |
|  |  | 010 | $\mathrm{fc} / 2^{16}$ | $\mathrm{fc} / 2^{17}$ |  |
|  |  | 011 | $\mathrm{fc} / 2^{14}$ | $\mathrm{fc} / 2^{15}$ |  |
|  |  | 100 | $\mathrm{fc} / 2^{13}$ | $\mathrm{fc} / 2{ }^{14}$ |  |
|  |  | 101 | $\mathrm{fc} / 2{ }^{12}$ | $\mathrm{fc} / 2^{13}$ |  |
|  |  | 110 | $\mathrm{fc} / 2{ }^{11}$ | $\mathrm{fc} / 2^{12}$ |  |
|  |  | 111 | $\mathrm{fc} / 2^{9}$ | $\mathrm{fc} / 2^{10}$ |  |

Note 1: fc: High-frequency clock [Hz], *: Don't care
Note 2: TBTCR is a write-only register and must not be used with any of read-modify-write instruction.
Note 3: Set bit7 and 4 in TBTCR to " 0 ".

Figure 2.3.2 Time Base Timer and Divider Output Control Register

Table 2.3.1 Time Base Timer Interrupt Frequency (Example: at fc $=16 \mathrm{MHz}$ )

| TBTCK | Time Base Timer Interrupt Frequency [Hz] |  |
| :---: | :---: | :---: |
|  | NORMAL, IDLE Mode |  |
|  | DV1CK $=0$ | DV1CK $=1$ |
| 000 | 1.90 | 0.95 |
| 001 | 7.62 | 3.81 |
| 010 | 244.14 | 122.07 |
| 011 | 976.56 | 488.28 |
| 100 | 1953.12 | 976.56 |
| 101 | 3906.25 | 1953.12 |
| 110 | 7812.50 | 3906.25 |
| 111 | 31250 | 15625 |

### 2.4 Watchdog Timer (WDT)

The watchdog timer is a fail-safe system to rapidly detect the CPU malfunctions such as endless looping caused by noise or the like, or deadlock and resume the CPU to the normal state.

The watchdog timer signal for detecting malfunction can be selected either a reset output or a pseudo non-maskable interrupt request. However, selection is possible only once after reset. At first the reset output is selected.

When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals.

Note: Care must be given in system design so as to protect the watchdog timer from disturbing noise. Otherwise the watchdog timer may not fully exhibit its functionality.

### 2.4.1 Watchdog Timer Configuration



Figure 2.4.1 Watchdog Timer Configuration

### 2.4.2 Watchdog Timer Control

Figure 2.4.2 shows the watchdog timer control registers (WDTCR1, WDTCR2). The watchdog timer is automatically enabled after reset.
(1) Malfunction detection methods using the watchdog timer

The CPU malfunction is detected at follows.

1. Setting the detection time, selecting output, and clearing the binary counter.
2. Repeatedly clearing the binary counter within the setting detection time.

Note: The watchdog timer consists of an internal divider and two-stage binary counter. Writing the clear code $\left(4 \mathrm{E}_{\mathrm{H}}\right)$ clears the binary counter, but not the internal divider. The minimum overflow time for the binary counter might be three quarters of the WDTCR1 (WDTT) time setting depending on when the clear code $\left(4 \mathrm{E}_{\mathrm{H}}\right)$ is written into the WDTCR2 register. So, write the clear code on a cycle which is shorter than that minimum overflow time.

If the CPU malfunctions such as endless looping or deadlock occur for any cause, the watchdog timer output will become active at the rising of an overflow from the binary counters unless the binary counters are cleared. At this time, when WDTOUT $=1 \mathrm{a}$ reset is generated, which drivers the $\overline{\mathrm{RESET}}$ pin low to reset the internal hardware and the external circuit. When WDTOUT $=0$, a watchdog timer interrupt (INTWDT) is generated.

The watchdog timer temporarily stops counting in STOP mode including warm-up or IDLE mode, and automatically restarts (Continues counting) when the STOP/IDLE mode is released.

Example: Sets the watchdog timer detection time to $2^{21} / \mathrm{fc}[\mathrm{s}]$ and resets the CPU malfunction.

|  | LD | (WDTCR2), 4EH | Clears the binary counters |
| :---: | :---: | :---: | :---: |
|  | LD | (WDTCR1), 00001101B | WDTT $\leftarrow 10$, WDTOUT $\leftarrow 1$ |
| Within $3 / 4$ of WDT detection time | LD | (WDTCR2), 4EH | Clears the binary counters |
|  |  |  | (always clear immediately before and after changing WDTT) |
| Within $3 / 4$ of WDT detection time | $\left[\begin{array}{c} \text { LD } \\ \vdots \\ i \\ i \end{array}\right.$ | (WDTCR2), 4EH | Clears the binary counters |
|  | L LD | (WDTCR2), 4EH | Clears the binary counters |


| Watchdog Timer Register 1 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WDTCR1 <br> (00034H) | 7 | 6 | 3 2 |  | 1 |  | (Initial value: **** 1001) |  |
|  |  |  | WDTEN |  |  |  |  |  |
|  | WDTEN | Watchdog timer enable/disable | 0 : Disable (It is necessary to write the disable code to WDTCR2) <br> 1: Enable |  |  |  |  | Write only |
|  | WDTT | Watchdog timer detection time [s] | NORMAL mode |  |  |  |  |  |
|  |  |  | DV1CK = 0 |  |  |  | DV1CK = 1 |  |
|  |  |  | 00 |  | $2^{25}$ /fc |  |  |  |
|  |  |  | 01 |  | $2^{23} / \mathrm{fc}$ |  | $2^{24} / \mathrm{fc}$ |  |
|  |  |  | 10 |  | $2^{21} / \mathrm{fc}$ |  | $2^{22} / \mathrm{fc}$ |  |
|  |  |  | 11 |  | $2^{19} / \mathrm{fc}$ |  | $2^{20} / \mathrm{fc}$ |  |
|  | WDTOUT | Watchdog timer output select | 0: Interrupt request <br> 1: Reset output |  |  |  |  |  |

Note 1: WDTOUT cannot be set to " 1 " by program after clearing WDTOUT to " 0 ".
Note 2: fc: High-frequency clock [Hz], *: Don't care
Note 3: WDTCR1 is a write-only register and must not be used with any of read-modify-write instructions.
Note 4: The watchdog timer must be disabled or the counter must be cleared immediately before entering to the STOP mode. When the counter is cleared, the counter must be cleared again immediately after releasing the STOP mode.

Note 5: Just right before disabling the watchdog timer, disable the acceptance of interrupts (DI) and clear the watchdog timer.
If the watchdog timer is disabled under conditions other than the above, the proper operation cannot be guaranteed.
Watchdog Timer Register 2

| WDTCR2 <br> (00035H) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (Initial value: **** ****) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ! |  |  |  | ! |  |  | (Initial |  |
|  | WDTCR2 | Watchdog timer control code write register |  |  | $4 \mathrm{E}_{\mathrm{H}}$ : Watchdog timer binary counter clear (Clear code) <br> $B 1_{H}$ : Watchdog timer disable (Disable code) <br> Others: Invalid |  |  |  | Write only |

Note 1: The disable code is invalid unless written when WDTEN $=0$.
Note 2: *: Don't care
Note 3: The binary counter of the watchdog timer must not be cleared by the interrupt task.
Note 4: Clears the binary counter does not clear the source clock.
It is recommended that the time to clear is set to $3 / 4$ of the detecting time.
Note 5: The watchdog timer counter must be disabled by writing the disable code $\left(\mathrm{B} 1_{H}\right)$ to WDRCR2 after writing WDTCR2 to. " $4 \mathrm{E}_{\mathrm{H}}$ ".

Figure 2.4.2 Watchdog Timer Control Registers
(2) Watchdog timer enable

The watchdog timer is enabled by setting WDTEN (Bit3 in WDTCR1) to " 1 ". WDTEN is initialized to " 1 " during reset, so the watchdog timer operates immediately after reset is released.

Example: Disables watchdog timer
LDW (WDTCR1), 00001000B ; WDTEN $\leftarrow 1$
(3) Watchdog timer disable

To disable the watchdog timer, clear the interrupt mask enable flag (IMF) to " 0 " and write the clear code ( $4 \mathrm{E}_{\mathrm{H}}$ ) into WDTCR2. Then, clear WDTEN (Bit3 in WDTCR1) to " 0 ". When WDTEN is " 0 ", the watchdog timer is disabled by writing the disable code $(\mathrm{B} 1 \mathrm{H})$ into WDTCR2. If WDTEN is cleared to "0" after the disable code has been written into WDTCR2, the watchdog timer is not disabled. While it is disabled, its binary counter is cleared.

Example:

| DI | $;$ | Disables interrupt acceptance. |  |
| :--- | :--- | :--- | :--- |
| LD | (WDTCR2), 4EH | $;$ | Clears the watchdog timer. |
| LDW | (WDTCR1), B101H | $;$ | Disables the watchdog timer. |
| EI |  | Enables interrupt acceptance. |  |

Table 2.4.1 Watchdog Timer Detection Time (Example: $\mathrm{fc}=16 \mathrm{MHz}$ )

| WDTT | Watchdog Timer Detection Time [s] |  |
| :---: | :---: | :---: |
|  | NORMAL Mode |  |
|  | DV1CK $=0$ | DV1CK $=1$ |
| 00 | 2.097 | 4.194 |
| 01 | 524.288 m | 1.048 |
| 10 | 131.072 m | 262.1 m |
| 11 | 32.768 m | 65.5 m |

### 2.4.3 Watchdog Timer Interrupt (INTWDT)

This is a pseudo non-maskable interrupt which can be accepted regardless of the contents of the EIR. If a watchdog timer interrupt or a software interrupt is already accepted, however, the new watchdog timer interrupt waits until the previous interrupt processing is completed (the end of the [RETN] instruction execution).

The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source with WDTOUT.

```
Example: Watchdog timer interrupt setting up
\begin{tabular}{lll} 
LD & SP, 023FH & \(;\) \\
LD & (WDTCR1), 00001000B & \(;\)
\end{tabular} WDTOUT \(\leftarrow 0\)
```


### 2.4.4 Watchdog Timer Reset

If the watchdog timer output becomes active, a reset is generated, which drivers the $\overline{\text { RESET }}$ pin (Sink open-drain input/output with pull-up) low to reset the internal hardware. The reset output time is about $8 / \mathrm{fc}$ to $24 / \mathrm{fc}$ [s] ( 0.5 to $1.5 \mu \mathrm{~s}$ at fc $=16.0 \mathrm{MHz}$ ).

Note: If there is any fluctuation in the oscillation frequency at the start of clock oscillation, the reset time includes error. Thus, regard the reset time as an approximate value.


Figure 2.4.3 Watchdog Timer Interrupt/Reset
2.5 16-Bit Timer/Counter 1 (TC1A)
2.5.1 Configuration


Figure 2.5.1 Timer/Counter 1

### 2.5.2 Control

The timer/counter 1 is controlled by a timer/counter 1 control register (TC1CR) and two 16-bit timer registers (TC1DRA and TC1DRB).


Note 1: fc: High-frequency clock [Hz]
Note 2: The timer register consists of two shift registers. A value set in the timer register is put in effect at the rising edge of the first source clock pulse that occurs after the upper data (TC1DRAH) are written. Therefore, the lower byte must be written before the upper byte (It is recommended that a 16 -bit access instruction be used in writing). Writing only the lower data (TC1DRAL) does not put the setting of the timer register in effect.
Note 3: Set the mode, source clock PPG control and timer F/F control when TC1 stops ( $\mathrm{TC} 1 \mathrm{~S}=00$ ).
Note 4: Auto capture can be used in only timer, event counter, and window modes.
Note 5: Values to be loaded to timer registers must satisfy the following condition.
TC1DRA > TC1DRB, TC1DRA > 1
Note 6: Always write " 0 " to TFF1 except PPG output mode.
Note 7: On entering STOP mode, the TC1 start control (TC1S) is cleared to "00" automatically. So, the timer stops. Once the STOP mode has been released, to start using the timer counter, set TC1S again.

Figure 2.5.2 Timer registers and TC1 control register

### 2.5.3 Function

Timer/counter 1 has five operating modes: Timer, external trigger timer, event counter, window, pulse width measurement.
(1) Timer mode

In this mode, counting up is performed using the internal clock. The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to " 0 ". Counting up resumes after the counter is cleared. The current contents of up counter can be transferred to TC1DRB by setting ACAP1 (Bit6 in TC1CR) to "1" (Software capture function). (Auto-capture function)

Table 2.5.1 Source Clock (Internal clock) for Timer/Counter 1 (Example: at fc $=16.0 \mathrm{MHz}$ )

| TC1CK | NORMAL, IDLE Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | DV1CK = 0 |  | DV1CK = 1 |  |
|  | Resolution [ $\mu \mathrm{s}]$ | Maximum Time <br> Setting [s] | Resolution [ $\mu \mathrm{s}]$ | Maximum Time <br> Setting [s] |
| 00 | 128.0 | 8.39 | 256.0 | 16.78 |
| 01 | 8.0 | 0.524 | 16.0 | 1.049 |
| 10 | 0.5 | 32.77 m | 1.0 | 65.54 m |

Example 1: Sets the timer mode with source clock $\mathrm{fc} / 2^{11}[\mathrm{~Hz}]$ and generates an interrupt 1 later (at fc $=16 \mathrm{MHz}$ )
LDW (TC1DRA), 1E84H ; Sets the timer register ( $1 \mathrm{~s} \div 2^{11} / \mathrm{fc}=1 \mathrm{E} 84 \mathrm{H}$ )
DI
SET (EIRL). 4 Enable INTTC1
EI
LD (TC1CR), 00000000B ; Selects the source clock and mode
LD (TC1CR), 00010000B ; Starts TC1

Example 2: Auto capture

| LD | (TC1CR), 01010000B | $;$ |
| :--- | :--- | :--- |
| LD | WA, (TC1DRB) | $;$ |



Figure 2.5.3 Timer Mode Timing Chart
(2) External trigger timer mode

In this mode, counting up is started by an external trigger. This trigger is the edge of the TC1 pin input. Either the rising or falling edge can be selected with TC1S. Source clock is an internal clock. The contents of TC1DRA is compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared to " 0 " and halted. The counter is restarted by the selected edge of the TC1 pin input.

When METT1 (Bit6 in TC1CR) is " 1 ", inputting the edge to the reverse direction of the trigger edge to start counting clears the counter, and the counter is stopped. Inputting a constant pulse width can generate interrupts. When METT1 is " 0 ", the reverse directive edge input is ignored. The TC1 pin input edge before a match detection is also ignored.

The TC1 pin input has the noise rejection; therefore, pulses of $7 / \mathrm{fc}$ [s] or less are rejected as noise. A pulse width of $13 / \mathrm{fc}$ [s] or more is required for edge detection in NORMAL or IDLE mode.

Example 1: Detects rising edge in TC1 pin input and generates an interrupt $100 \mu \mathrm{~s}$ later. (at $\mathrm{fc}=16.0 \mathrm{MHz}$, DV1CK = 1)
LDW (TC1DRA), 0064H ; $100 \mu \mathrm{~S} \div 2^{4} / \mathrm{fc}=64 \mathrm{H}$
DI
SET (EIRL). 4 ; INTTC1 interrupt enable
LD (TC1CR), 00001000B $\quad ; \quad$ Selects the source clock and mode
Example 2: Generates an interrupt, inputting " $L$ " level pulse (Pulse width: 4 ms or more) to the TC1 pin. (at fc = 16.0 MHz, DV1CK = 1)

| LDW | (TC1DRA), 00FAH | $;$ | $4 \mathrm{~ms} \div 2^{8} / \mathrm{fc}=\mathrm{FAH}$ |
| :--- | :--- | :--- | :--- |
| DI |  |  |  |
| SET | (EIRL). 4 |  | INTTC1 interrupt enable |
| EI |  |  |  |
| LD | (TC1CR), 00000100B | $;$ | Selects the source clock and mode |
| LD | (TC1CR), 01110100B | $;$ | TC1 external trigger start, METT1 = 1 |



Figure 2.5.4 External Trigger Timer Mode Timing Chart
(3) Event counter mode

In this mode, events are counted at the edge of the TC1 pin input (Either the rising or falling edge can be selected with the external trigger TC1CR<TC1S>). The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared.

Match detect is executed on other edge of count-up. A match can not be detected and INTTC1 is not generated when the pulse is still in same state.

Setting ACAP1 to " 1 " transfers the current contents of up counter to TC1DRB (Auto-capture function).


Figure 2.5.5 Event Counter Mode Timing Chart

Table 2.5.2 Input Pulse Width for Timer/Counter 1

|  | Minimum Pulse Width [s] |
| :---: | :---: |
|  | NORMAL/IDLE |
| "H" Width | $2^{3} / \mathrm{fc}$ |
| "L" Width | $2^{3} / \mathrm{fc}$ |

(4) Window mode

Counting up is performed on the rising edge of the pulse that is the logical AND-ed product of the TC1 pin input (Window pulse) and an internal clock. The contents of TC1DRA are compared with the contents of up counter. If a match is found, an INTTC1 interrupt is generated, and the counter is cleared. Positive or negative logic for the TC1 pin input can be selected with bit4 or 5 in TC1CR.

It is necessary that the maximum applied frequency be such that the counter value can be analyzed by the program. That is; the frequency must be considerably slower than the selected internal clock.


Figure 2.5.6 Window Mode Timing Chart
(5) Pulse width measurement mode

In this mode, counting is started by the external trigger (Set to external trigger start by TC1CR). The trigger can be selected either the rising or falling edge of the TC1 pin input. The source clock is used an internal clock. On the next falling (rising) edge, the counter contents are transferred to TC1DRB and an INTTC1 interrupt is generated. The counter is cleared when the single edge capture mode is set. When double edge capture is set, the counter continues and, at the next rising (falling) edge, the counter contents are again transferred to TC1DRB. If a falling (rising) edge capture value is required, it is necessary to read out TC1DRB contents until a rising (falling) edge is detected. Falling or rising edge is selected with the external trigger TC1S (Bit4 or 5 in TC1CR), and single edge or double edge is selected with MCAP1 (Bit6 in TC1CR).

Note 1: Be sure to read the captured value from TC1DRB before the next trigger edge is detected. If fail to read it, it becomes undefined. It is recommended that a 16-bit access instruction be used to read from TC1DRB.
Note 2: If either the falling or rising edge is used in capturing values, the counter stops at " 1 " after a value has been captured until the next edge is detected. So, the value captured next will become " 1 " larger than the value captured right after capturing starts.



Figure 2.5.7 Pulse Width Measurement Mode Timing Chart

### 2.6 16-Bit Timer/Counter 2 (TC2A)

2.6.1 Configuration


Figure 2.6.1 Timer/Counter 2 (TC2)

### 2.6.2 Control

The timer/counter 2 is controlled by a timer/counter 2 control register (TC2CR) and a 16-bit timer register 2 (TC2DR). Reset does not affect TC2DR.


Figure 2.6.2 Timer Registers 2 and TC2 Control Register

### 2.6.3 Function

The timer/counter 2 has three operating modes: Timer, event counter and window modes.
(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC2DR are compared with the contents of up counter. If a match is found, a timer/counter 2 interrupt (INTTC2) is generated, and the counter is cleared. Counting up is resumed after the counter is cleared.

Table 2.6.1 Source Clock (Internal clock) for Timer/Counter 2 (at fc = 16.0 MHz)

| TC2CK | NORMAL, IDLE mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | DV1CK $=0$ |  | DV1CK = 1 |  |
|  | Resolution | Maximum <br> Time Setting | Resolution | Maximum <br> Time Setting |
| 000 | $524.3[\mathrm{~ms}]$ | $9.54[\mathrm{~h}]$ | $1.05[\mathrm{~s}]$ | $19.1[\mathrm{~h}]$ |
| 001 | $512.0[\mu \mathrm{~s}]$ | $33.6[\mathrm{~s}]$ | $1.02[\mathrm{~ms}]$ | $1.12[\mathrm{~min}]$ |
| 010 | $16.0[\mu \mathrm{~s}]$ | $1.05[\mathrm{~s}]$ | $32.0[\mu \mathrm{~s}]$ | $2.09[\mathrm{~s}]$ |
| 011 | $0.5[\mu \mathrm{~s}]$ | $32.8[\mathrm{~ms}]$ | $1.0[\mu \mathrm{~s}]$ | $65.5[\mathrm{~ms}]$ |
| 100 | Reserved | Reserved | Reserved | Reserved |
| 101 | Reserved | Reserved | Reserved | Reserved |

Example: Sets the source clock $\mathrm{fc} / 2^{4}[\mathrm{~Hz}]$ and generates an interrupt event 25 ms (at fc $=16 \mathrm{MHz}, \mathrm{DV} 1 \mathrm{CK}=1$ )

| LDW | (TC2DR), 61A8H | $;$ | Sets TC2DR $\left(25 \mathrm{~ms} \div 2^{4} / \mathrm{fc}=61 \mathrm{~A} 8 \mathrm{H}\right)$ |
| :--- | :--- | :--- | :--- |
| DI |  |  |  |
| SET | (EIRH).6 | Enable INTTC2 interrupt |  |
| EI |  |  |  |
| LD | (TC2CR), 00001100B | $;$ | Selects TC2 source clock |
| LD | (TC2CR), 00101100B | $;$ | Starts TC2 |



Figure 2.6.3 Timer Mode Timing Chart
(2) Event counter mode

In this mode, events are counted on the rising edge of the TC2 pin input. The contents of TC2DR are compared with the contents of the up counter. If a match is found, an INTTC2 interrupt is generated, and the counter is cleared. The minimum pulse width to the TC2 pin is shown in Table 2.6.2. Two or more machine cycles are required for both the "H" and "L" levels of the pulse width. Match detect is executed on the falling edge of the TC2 pin. A match can not be detected and INTTC2 is not generated when the pulse is still in a falling state.

Example: Sets the event counter mode and generates an INTTC2 interrupt 640 counts later.

| LDW | (TC2DR), 640 | $;$ | Sets TC2DR |
| :--- | :--- | :--- | :--- |
| DI |  |  |  |
| SET | (EIRH). 6 |  | Enables INTTC2 interrupt |
| EI |  |  |  |
| LD | (TC2CR), 00011100B | $;$ | Selects TC2 source clock |
| LD | (TC2CR), 00111100B | $;$ | Starts TC2 |

Table 2.6.2 Timer/Counter 2 External Clock Source

|  | Minimum Pulse Width [S] |
| :---: | :---: |
|  | "H" Width |
| "L" Width | $2^{3} / \mathrm{fc}$ |



Figure 2.6.4 Event Counter Mode Timing Chart
(3) Window mode

In this mode, counting up performed on the rising edge of an internal clock during TC2 external pin input (window pulse) is "H" level. The contents of TC2DR are compared with the contents of up counter. If a match found, an INTTC2 interrupt is generated, and the up counter is cleared.

The maximum applied frequency (TC2 input) must be considerably slower than the selected internal clock.

Example: Generates an interrupt, inputting "H" level pulse width of 120 ms or more. (at $\mathrm{fc}=16.0 \mathrm{MHz}$, DV1CK =1)

LDW (TC2DR), 0075H ; Sets TC2DR $\left(120 \mathrm{~ms} \div 2^{14} / \mathrm{fc}=0075 \mathrm{H}\right)$
DI
SET (EIRH). 6 ; Enables INTTC2 interrupt
EI
LD (TC2CR), 00000101B ; Selects TC2 source clock
LD (TC2CR), 00100101B ; Starts TC2


Figure 2.6.5 Window Mode Timing Chart

### 2.7 8-Bit Timer/Counter 3 (TC3B)

### 2.7.1 Configuration



Figure 2.7.1 Timer/Counter 3 (TC3)

### 2.7.2 Control

The timer/counter 3 is controlled by a timer/counter 3 control register (TC3CR) and two 8-bit timer registers (TC3DRA and TC3DRB) and port multiplex control register (PMPXCR).


Note 1: fc: High-frequency clock [Hz], *: Don't care.
Note 2: Set the mode and source clock when the TC3 stops $(T C 3 S=0)$.
Note 3: Values to be loaded to timer register 3A must satisfy the following condition TC3DRA > 0 (in the timer and event counter mode).

Note 4: Auto-capture can be used only int the timer and event counter mode.
Note 5: Before setting TC3DRA or switching the operation mode, stop the TC3 (TC3S = 0).
Note 6: When STOP mode is started, timer counter is stopped and TC3 start control (TC3S) is cleared to " 0 " automatically. Set TC3S to "1" after STOP mode is released for restarting timer counter.
Note 7: TC3CR, TCESCR is a write-only register and must not be used with any of the read-modify-write instructions.

PMPXCR
 (Initial value: 00** **00)


Note 8 Always write " 0 " to bit7 in PMPXCR.

Figure 2.7.2 Timer Registers 3 and TC3 Control Register

### 2.7.3 Function

The timer/counter 3 has three operating modes: timer, event counter, and capture mode. When it is used in the capture mode, the noise rejection time of TC3 pin input can be set by remote control receive control register.
(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC3DRA are compared with the contents of up counter. If a match is found, a timer/counter 3 interrupt (INTTC3) is generated, and the up counter is cleared. The current contents of up counter are loaded into TC3DRB by setting ACAP (Bit6 in TC3CR) to "1" (Auto-capture function).

The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow (FFH) and 00 H can not be loaded correctly. It is necessary to consider the count cycle.


Table 2.7.1 Source Clock (Internal clock) for Timer/Counter 3 (Example: at $\mathrm{fc}=16.0 \mathrm{MHz}$ )

| TC3CK | NORMAL, IDLE Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | DV1CK = 0 |  | DV1CK = 1 |  |
|  | Resolution [ $\mu \mathrm{s}]$ | Maximum Setting <br> Time [ms] | Resolution [ $\mu \mathrm{s}]$ | Maximum Setting <br> Time [ms] |
| 000 | 512 | 130.6 | 1024 | 261.1 |
| 001 | 256 | 65.3 | 512 | 130.6 |
| 010 | 128 | 32.6 | 256 | 65.3 |
| 011 | 64 | 16.3 | 128 | 32.6 |
| 100 | 32 | 8.2 | 64 | 16.3 |
| 101 | 16 | 4.1 | 32 | 8.2 |
| 110 | 8 | 2.0 | 16 | 4.1 |



Figure 2.7.3 Timer Mode Timing Chart
(2) Event counter mode

In this mode, the TC3 pin input pulses are used for counting up Either the rising on falling edge can be selected with TC3ES (Bit0 in PMPXCR). The contents of TC3DRA are compared with the contents of the up counter. If a match is found, an INTTC3 interrupt is generated and the counter is cleared. Match detect is executed on the falling edge of the TC3 pin. A match can not be detected, and INTTC3 is not generated when the pulse is still in a falling state.
The maximum applied frequency is shown in Table 2.7.2. Two or more machine cycles are required for both the high and low levels of the pulse width.

The current contents of up counter are loaded into TC3DRB by setting ACAP (Bit6 in TC3CR) to " 1 " (Auto-capture function).
The contents of up counter can be easily confirmed by executing the read instruction (RD instruction) of TC3DRB. Loading the contents of up counter is not synchronized with counting up. The contents of over flow ( FFH ) and 00 H can not be loaded correctly. It is necessary to consider the count cycle.

Example: Generates an interrupt every 0.5 s , inputting 50 Hz pulses to the TC3 pin.

| LD | (TC3CR), 00001110B | $;$ | Sets TC3 mode and source clock |
| :--- | :--- | :--- | :--- |
| LD | (TC3DRA), 19H | $;$ | $0.5 \mathrm{~s} \div 1 / 50=25=19 \mathrm{H}$ |
| LD | (TC3CR), 00011100B | $;$ | Starts TC3 |

Table 2.7.2 Source Clock (External clock) for Timer/Counter

|  | Minimum Applied Frequency [Hz] |
| :--- | :---: |
|  | NORMAL, IDLE Mode |
| "H" Width | $2^{2} / \mathrm{fc}$ |
| "L" Width | $2^{2} / \mathrm{fc}$ |



Figure 2.7.4 Event Counter Mode Timing Chart
(3) Capture mode

In this mode, the pulse width, period and duty of the TC3 pin input are measured in this mode, which can be used in decoding the remote control signals or distinguishing AC $50 / 60 \mathrm{~Hz}$, etc. The TC3 pin input can have its polarity changed between normal and inverse by using the TC3ES Register.
a. If TC3ES $=$ " 0 " (Non-inverting input)

Once command operation has started, the counter free-runs on an internal source clock.

When the falling edge of the TC3 pin input is detected, the counter value is loaded into TC3DRB. When the rising edge is detected, the counter value is loaded into TC3DRA, and the counter is cleared, generating an INTTC3 interrupt.

If the rising edge is detected right after command operation has started, no capture to TC3DRB and an INTTC3 interrupt occurs only on capture to TC3DRA. If a read instruction is executed for TC3DRB, the value that exists at the end of the previous capture (immediately after a reset, "FF") is read.
b. If TC3ES = " 1 " (Inverse input)

Once command operation has started, the counter free-runs on an internal clock.

When the rising edge of the TC3 pin input is detected, the counter value is loaded into TC3DRB. When the falling edge is detected, the counter value is loaded into TC3DRA, and the counter is cleared, generating an INTTC3 interrupt.

If the falling edge is detected right after command operation has started, the counter value is not captured into TC3DRB and an INTTC3 interrupt occurs only on capture to TC3DRA. If a read instruction is executed for TC3DRB, the value that exists at end of the previous capture (immediately after a reset, "FF") is read.

The minimum acceptable input pulse width is equal to the length of one source clock period selected by TC3CR <TC3CK>.

Table 2.7.3 TC3INV-based Capture Input Edges

| TC3ES | Capture into TC3DRB | Capture into TC3DRA | INTTC3 Interrupt |
| :---: | :---: | :---: | :---: |
| "0" <br> (Non-inverting input) | Falling edge | Rising edge |  |
| "1" input) <br> (Inverting ing | Rising edge | Falling edge |  |

Note: Capture of the TC3 pin input requires at least 1 cycle of the selected source clock.

TC3S
Source clock
Up counter
TC3 pin input
Internal waveform
(Normal)
TC3DRA
TC3DRB
INTTC3 interrupt
Reading TC3DRA
TC3S
Source clock
Up counter
TC3 pin input
Internal waveform
(Invert)
TC3DRA
TC3DRB
INTTC3 interrupt
Reading TC3DRA

Figure 2.7.5 Capture Mode Timing Chart

The edge of TC3 pin input is detected in the remote control receive circuit with noise rejection. The remote control receive circuit is controlled by the remote control receive control register (RCCR). The remote control receive status register (RCSR) can monitor the polarity selection and noise rejection circuit.


Figure 2.7.6 Remote Control Receiving Circuit


Figure 2.7.7 Remote Control Rceive Control Register and Remote Control Receive Status Register

Table 2.7.4 Combination between The Polarity and The Edge Selection

| RPOLS | TC3 Pin Input Pulse <br> (Interrupt occurrence is shown as allow.) | Measurement |
| :--- | :---: | :---: |
| 0 | T |  |

Note: When TC3CK is used in RCSCK, do not select an external clock to the TC3CK.


Figure 2.7.8 Remote Control Receive Circuit Timing Chart

### 2.8 8-Bit Timer/Counter 4 (TC4)

### 2.8.1 Configuration



Figure 2.8.1 Timer/Counter 4 (TC4)

### 2.8.2 Control

The timer/counter 4 is controlled by a timer/counter 4 control register (TC4CR) and an 8-bit timer register 4 (TC4DR). Reset does not affect TC4DR.


Note 1: fc: High-frequency clock [Hz], *: Don't care
Note 2: Values to be loaded to the timer register must satisfy the following condition ( $1 \leq \operatorname{TC} 4 D R \leq 255$ ).
Note 3: When the TC4 is started (TC4S $=0 \rightarrow 1$ ) or disabled (TC4S $=1 \rightarrow 0$ ) or while the TC4 is operating (TC4S = $1 \rightarrow 1$ ), do not write to TC4M and TC4CK in TC4CR. If these registers are selected/changed during these operations, counting up is not performed properly.

Note 4: When STOP mode is started, timer counter is stopped and cleared. Set TC4S to " 1 " after STOP mode is released for restarting timer counter.

Note 5: Undefined values are read from bits 6 and 7 of TC4CR.
Note 6: Do not change TC4DR while the TC4 is operating.


Note 1: TC4CR, TC4DR and PMPXCR are write only register and must not be used with any of the read-modify-write instructions such as SET, CLR, etc.

Figure 2.8.2 Timer Register 4 and TC4 Control Register

### 2.8.3 Function

The timer/counter 4 has two operating modes: timer, event counter mode.
(1) Timer mode

In this mode, the internal clock is used for counting up. The contents of TC4DR are compared with the contents of up counter. If a match is found, an INTTC4 interrupt is generated and the up counter is cleared to " 0 ". Counting up resumes after the up counter is cleared.

Table 2.8.1 Source Clock (Internal clock) for Timer/Counter 4 (Example: at fc $=16.0 \mathrm{MHz}$ )

| TC4CK | NORMAL, IDLE mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | DV1CK $=0$ |  | DV1CK = 1 |  |
|  | Resolution [ $\mu \mathrm{s}]$ | Maximum Setting <br> Time [ms] | Resolution [ $\mu \mathrm{s}]$ | Maximum Setting <br> Time [ms] |
| 000 | 128.0 | 32.6 |  | 65.3 |
| 001 | 8.0 | 2.0 | 16.0 | 4.1 |
| 010 | 2.0 | 0.510 | 4.0 | 1.0 |
| 100 | 0.5 | 0.128 | 1.0 | 0.255 |

(2) Event counter mode

In this mode, the TC4 pin input (External clock) pulse is used for counting up. Either the rising or falling edge can be selected with TC4ES (Bit1 PMPXCR). The contents of TC4DR are compared with the contents of the up counter. If a match is found, an INTTC4 interrupt is generated and the counter is cleared. The maximum applied frequency is shown Table 2.8.2. Two or more machine cycles are required for both the high and low level of the pulse width.

Note: The event counter mode can only be used in NORMAL or IDLE mode.

Table 2.8.2 Timer/Counter 4 External Clock Source

|  | Minimum Input Pulse Width [s] |
| :---: | :---: |
|  | NORMAL1, IDLE1 Mode |
| "H" Width | $2^{3} \mathrm{fc}$ |
| " L " Width | $2^{3} \mathrm{fc}$ |

### 2.9 Serial Bus Interface (SBI-ver. D)

The TMP88CS38B and TMP88CM38B/CP38B has a 1 -channel serial bus interface which employs a clocked-synchronous 8-bit serial bus interface and an $\mathrm{I}^{2} \mathrm{C}$ bus (a bus system by Philips). The serial bus interface pins are selectively used as either channel 0 or channel 1.

The serial interface is connected to external devices through P35 (SDA0)/P52 (SDA1) and P34 (SCL0)/P51 (SCL1) in the I ${ }^{2} \mathrm{C}$ bus mode; and through P53 ( $\overline{\mathrm{SCK}}$ ), P52 (SO1) and P51 (SI1) in the clocked-synchronous 8-bit SIO mode.

The serial bus interface pins are also used for the P3/P5 port. When used for serial bus interface pins, set the P3/P5 output latches of these pins to " 1 ". When not used as serial bus interface pins, the P3/P5 port is used as a normal I/O port.

Note 1: When P3 and P5 is used as serial bus interface pins, P35, P34, P51 and P50 should be set as a sink open-drain output by clearing PSELCR to " 0 ".

Note 2: The I ${ }^{2}$ C of TMP88CS38B and TMP88CM38B/CP38B can be used only in the standard mode of $I^{2} C$. The fast mode and the high speed mode can not be used.

### 2.9.1 Configuration



Figure 2.9.1 Serial Bus Interface (SBI)

### 2.9.2 Control

The following registers are used for control the serial bus interface and monitor the operation status.

- Serial bus interface control register A (SBICRA)
- Serial bus interface control register B (SBICRB)
- Serial bus interface data buffer register (SBIDBR)
- $\quad \mathrm{I}^{2} \mathrm{C}$ bus address register (I2CAR)
- Serial bus interface status register A (SBISRA)
- Serial bus interface status register B (SBISRB)
- Serial clock source control register (SCCRB)
- Serial clock control status register (SCSR)

The above registers differ depending on a mode to be used. Refer to section 2.9.7 "I ${ }^{2} \mathrm{C}$ Bus Mode Control" and 2.9.9"Clocked-synchronous 8-Bit SIO Mode Control".

### 2.9.3 Serial Clock Source Control

A serial bus interface circuit can reduce the power consumption by stopping a serial clock generater.


Figure 2.9.2 Serial Clock Source

### 2.9.4 Channel Select

A serial bus interface circuit can select I/O pin when a serial bus interface is used for $\mathrm{I}^{2} \mathrm{C}$ bus mode.


Note 1: When SIO mode, don't use channel 0. Therefore, set to " 1 " in PMPXCR at SIO mode.
Note 2: Always write " 0 " to bit7 in PMPXCR.
Note 3: *: Don't care

Figure 2.9.3 Channel Select

### 2.9.5 Software Reset

A serial bus interface circuit has a software reset function, when a serial bus interface circuit is locked by an external noise, etc.

To occur software reset, write " 01 ", " 10 " into the SWRST (Bit1, 0 in SBICRB). During software reset, the SWRMON (Bit0 in SBISRA) is clear to " 0 ".

### 2.9.6 The Data Format in The $\mathrm{I}^{2} \mathrm{C}$ bus Mode

The data format when using the TMP88CS38B and TMP88CM38B/CP38B in the $\mathrm{I}^{2} \mathrm{C}$ bus mode are shown in as below.
(a) Addressing format

(b) Addressing format (with restart)

(c) Free data format


S: Start condition
R/ $\bar{W}$ : Direction bit
ACK: Acknowledge bit
P: Stop condition
Figure 2.9.4 Data Format in $\mathrm{I}^{2} \mathrm{C}$ Bus Mode

### 2.9.7 $\quad I^{2} C$ Bus Mode Control

The following registers are used to control the serial bus interface (SBI) and monitor the operation status in the $\mathrm{I}^{2} \mathrm{C}$ bus mode.


Note 1: fc: High-frequency clock [Hz], *: Don't care
Note 2: Set the BC to "000" before switching to 8 -bit SIO bus mode.
Note 3: SBICRA cannot be used with any of read-modify-write instructions such as bit manipulation, etc.
Note 4: Do not set the SCK frequency to over 100 kHz in the $\mathrm{I}^{2} \mathrm{C}$ bus mode.
Serial Bus Interface Data Buffer Register


Note 2: The data which was written into SBIDBR cannot be read, since a write data buffer and a read buffer are independent in SBIDBR. Therefore, SBIDBR cannot be used with any of read-modify-write instructions such as bit manipulation, etc.
Note 3: *: Don't care
$\mathrm{I}^{2} \mathrm{C}$ bus Address Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I2CAR | Slave address |  |  |  |  |  |  | S |
| (00022H) | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 | SA0 | ALS |

(Initial value: 0000 0000)

| SA | Slave address selection |  | Write <br> only |
| :---: | :--- | :--- | :---: |
| ALS | Address recognition mode <br> specification | 0: Slave address recognition <br> $1:$ Non slave address recognition |  |

Note 1: I2CAR is write-only register and cannot be used with any of read-modify-write instruction such as bit manipulation, etc.
Note 2: Do not set I2CAR to "00H" to avoid the incorrect response of acknowledgment in slave mode. If " 00 H " is set to I2CAR as the slave address and received " 01 H " in slave mode, the device might transmit the acknowledgement incorrectly.

Figure 2.9.5 Serial Bus Interface Control Register A, Serial Bus Interface Data Buffer Register and $I^{2} C$ Bus Address Register In The $I^{2} C$ Bus Mode

Serial Bus Interface Control Register B


Note 1: Switch a mode to port after confirming that the bus is free.
Note 2: Switch a mode to $I^{2} \mathrm{C}$ bus mode or clock synchronous 8 -bit SIO mode after confirming that the port is high level.
Note 3: SBICRB has write-only register and must not be used with any of read-modify-write instructions such as bit manipulation, etc.
Note 4: When the SWRST (Bit1, 0 in SBICRB) is written to " 01 ", " 10 ", software reset (Four machine cycles) is occurred.
This time, control the serial bus interface and monitor the operation status registers except the SBIM (Bit3, 2 in SBICRB) and the CHS (Bit6 in PMPXCR) are reseted.
Control the serial bus interface and monitor the operation status registers are SBICRA, SBICRB, SBIDBR, I2CAR, SBISRA, SBISRB, SCCRA and SCSR.

Serial Bus Interface Status Register A

SBISRA (00020H)

*: Don't care
Serial Bus Interface Status Register B


Figure 2.9.6 Serial Bus Interface Control Register B and Serial Bus Interface Status Register $A / B$ in the $I^{2} C$ Bus Mode
(1) Acknowledgement mode specification
a. Acknowledgement mode (ACK = " 1 ")

To set the device as an acknowledgement mode, the ACK (bit4 in SBICRA) should be set to " 1 ". When a serial bus interface circuit is a master mode, an additional clock pulse is generated for an acknowledge signal. In a slave mode, a clock is counted for the acknowledge signal.

In the master transmitter mode, the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In the master receiver mode, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle.

In a slave mode, when a received slave address matches to a slave address which is set to the I2CAR or when a "GENERAL CALL" is received, the SDA pin is set to low level generating an acknowledge signal. After the matching of slave address or the detection of "GENERAL CALL", in the transmitter the SDA pin is released in order to receive an acknowledge signal from the receiver during additional clock pulse cycle. In a receiver, the SDA pin is set to low level generation an acknowledge signal during additional clock pulse cycle after the matching of slave address or the detection of "GENERAL CALL".

The Table 2.9.1 shows the SCL and SDA pins status in acknowledgement mode.

Table 2.9.1 SCL and SDA Pins Status in Acknowledgement Mode

| Mode |  | Pin | Transmitter | Receiver |
| :---: | :---: | :---: | :---: | :---: |
| Master |  | SCL | An additional clock pulse is generated. |  |
|  |  | SDA | Released in order to receive and acknowledge signal. | Set to low level generating an acknowledge signal. |
| Slave |  | SCL | A clock is counted for the acknowledge signal. |  |
|  | SDA | When slave address matches or a general call is detected | - | Set to low level generating an acknowledge signal. |
|  |  | After matching of slave address or general call | Released in order to receive an acknowledge signal. | Set to low level generating an acknowledge signal. |

b. Non-acknowledgement mode (ACK = "0")

To set the device as a non-acknowledgement mode, the ACK should be cleared to " 0 ". In the master mode, a clock pulse for an acknowledge signal is not generated. In the slave mode, a clock for a acknowledge signal is not counted.
(2) Number of transfer bits

The BC (bits 7 to 5 in SBICRA) is used to select a number of bits for next transmitting and receiving data.

Since the BC is cleared to " 000 " as a start condition, a slave address and direction bit transmissions are always executed in 8 bits. Other than these, the BC retains a specified value.
(3) Serial clock
a. Clock source

The SCK (bits 2 to 0 in SBICRA) is used to select a maximum transfer frequency output from the SCL pin in the master mode.

Four or more machine cycles are required for both high and low levels of pulse width in the external clock which is input from SCL pin.

Note: Since the $I^{2}$ C of TMP88CS38B AND TMP88CM38B/CP38B can not be used as the Fast mode and the High Speed mode, do not set SCK as the frequency that is over 100 kHz .

This $I^{2} \mathrm{C}$ bus circuit does not support high-speed mode, it supports standard mode only. Set the baud rates, which have been calculated according to the formula below, to meet the specifications of the I2C bus, such as the smallest pulse width of $\mathrm{t}_{\text {Low, }}$,

fc: High-frequency clock
Figure 2.9.7 Clock Source
b. Clock synchronization

In the $\mathrm{I}^{2} \mathrm{C}$ bus mode, in order to drive a bus with a wired AND, a master device which pulls down a clock pulse to low will, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse.

The serial bus interface circuit has a clock synchronization function. This function ensures normal transfer even if there are two or more masters on the same bus.

The example explains clock synchronization procedures when two masters simultaneously exist on a bus.


Figure 2.9.8 Clock Synchronization
As master 1 pulls down the SCL pin to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, master 2 resets counting a clock pulse in the high level and sets the SCL pin to the low level.

Master 1 finishes counting a clock pulse in the low level at point "b" and sets the SCL pin to the high level. Since master 2 holds the SCL line of the bus at the low level, master 1 waits for counting a clock pulse in the high level. After master 2 sets a clock pulse to the high level at point "c" and detects the SCL line of the bus at the high level, master 1 starts counting a clock pulse in the high level. Then, the master, which has finished the counting a clock pulse in the high level, pulls down the SCL pin to the low level.

The clock pulse on the bus is deteminded by the master device with the shortest high-level period and the master device with the longest low-level period from among those master devices connected to the bus.
(4) Slave address and address recognition mode specification

When the serial bus interface circuit is used with an addressing format to recognize the slave address, clear the ALS (Bit0 in I2CAR) to " 0 ", and set the SA (Bits 7 to 1 in I2CAR) to the slave address.

When the serial bus interfac circuit is used with a free data format not to recognize the slave address, set the ALS to " 1 ". With a free data format, the slave address and the direction bit are not recognized, and they are processed as data from immediately after start condition.
(5) Master/slave selection

To set a master device, the MST (Bit7 in SBICRB) should be set to "1". To set a slave device, the MST should be cleared to " 0 ".

When a stop condition on the bus or an arbitration lost is detected, the MST is cleared to " 0 " by the hardware.
(6) Transmitter/receiver selection

To set the device as a transmitter, the TRX (Bit6 in SBICRB) should be set to " 1 ". To set the device as a receiver, the TRX should be cleared to " 0 ". When data with an addressing format is transferred in the slave mode, the TRX is set to " 1 " by a hardware if the direction bit ( $\mathrm{R} / \overline{\mathrm{W}}$ ) sent from the master device is " 1 ", and is cleared to " 0 " by a hardware if the bit is " 0 . In the master mode, after an acknowledge signal is returned from the slave device, the TRX is cleared to " 0 " by a hardware if a transmitted direction bit is " 1 ", and is set to " 1 " by a hardware if it is " 0 ". When an acknowledge signal is not returned, the current condition is maintained.

When a stop condition on the bus or an arbitration lost is detected, the TRX is cleared to " 0 " by the hardware. The following table show TRX changing conditions in each mode and TRX value after changing.

| Mode | Direction Bit | Conditions | TRX after Changing |
| :---: | :---: | :---: | :---: |
| Slave mode | "0" | A received slave address is the same value set to I2CAR | "0" |
|  | "1" |  | "1" |
| Master mode | "0" | ACK signal is returned | "1" |
|  | "1" |  | "0" |

When a serial bus interface circuit operates in the free data format, a slave address and a direction bit are not recognized. They are handled as data just after generating a start condition. The TRX is not changed by a hardware.
(7) Start/stop condition generation

When the BB (Bit5 in SBICRB) is " 0 ", a slave address and a direction bit which are set to the SBIDBR are output on a bus after generating a start condition by writing " 1 " to the MST, TRX, BB and PIN. It is necessary to set transmitted data to the SBIDBR and set " 1 " to ACK beforehand.


Figure 2.9.9 Start Condition Generation and Slave Address Generation
When the BB is " 1 ", sequence of generating a stop condition is started by writeng " 1 " to the MST, TRX and PIN, and " 0 " to the BB. Do not modify the contents of MST, TRX, BB and PIN until a stop condition is generated on a bus.


Figure 2.9.10 Stop Condition Generation
When a stop condition is generated and the SCL line on a bus is pulled down to low level by another device, a stop condition is generated after releasing the SCL line.

The bus condition can be indicated by reading the contents of the BB (Bit5 in SBISRB). The BB is set to " 1 " when a start condition on a bus is detected and is cleared to " 0 " when a stop condition is detected.
(8) Interrupt service request and cancel

When a serial bus interface circuit is in the master mode and transferring a number of clocks set by the BC and the ACK is complete, a serial bus interface interrupt request (INTSBI) is generated.

In the slave mode, the conditions of generating INTSBI are follows:

- At the end of acknowledge signal when the received slave address matches to the value set by the I2CAR
- At the end of acknowledge signal when a "GENERAL CALL" is received
- At the end of transferring or receiving after matching of slave address or receiving of "GENRAL CALL"
When a serial bus interface interrupt request occurs, the PIN (Bit4 in SBISR) is cleared to " 0 ". During the time that the PIN is " 0 ", the SCL pin is pulled down to low level.

Either writing data to SBIDBR or reading data from the SBIDBR sets the PIN to " 1 ".
The time from the PIN being set to " 1 " until the SCL pin is released takes tLOW.
Although the PIN (Bit4 in SBICRB) can be set to " 1 " by the program, the PIN can not be cleared to " 0 " by the program.

Note: If the arbitration lost occurs, when the slave address does not match, the PIN is not cleared to " 0 " even thought INTSBI is generated.
(9) Serial bus interface operating mode selection

The SBIM (Bit3 and 2 in SBICRB) is used to specify a serial bus interface operation mode.

Set the SBIM to " 10 " in order to change a operation mode to $\mathrm{I}^{2} \mathrm{C}$ bus mode. Before changing operation mode, confirm serial bus interface pins in a high level. And switch a mode to port after confirming that a bus is free.
(10) Arbitration lost detection monitor

Since more than one master device can exist simultaneously on a bus in the $\mathrm{I}^{2} \mathrm{C}$ bus mode, a bus arbitration procedure is implemented in order to guarantee the contents of transferred data.

Data on the SDA line is used for bus arbitration of the $\mathrm{I}^{2} \mathrm{C}$ bus.
The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on a bus. Master 1 and master 2 output the same data until point "a". After master 1 outputs " 1 " and master 2 , " 0 ", the SDA line of a bus is wired AND and the SDA line is pulled-down to the low level by master 2 . When the SCL line of a bus is pulled up at point "b", the slave device reads data on the SDA line, that is data in master 2.

Data transmitted from master 1 becomes invalid. The state in master 1 is called "arbitration lost". A master device which loses arbitration releases the SDA pin and the SCL pin in order not to effect data transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word.


Figure 2.9.11 Arbitration Lost

The serial bus interface circuit compares levels of a SDA line of a bus with its those SDA pin at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and the AL (Bit3 in SBISRB) is set to " 1 ".

When the AL is set to " 1 ", the MST and TRX are cleared to " 0 " and the mode is switched to a slave receiver mode.

The AL is cleared to "0" by writing or reading data to or from the SBIDBR or writing data to the SBICRB.


Figure 2.9.12 Example of when a Serial Bus Interface Circuit is a Master B
(11) Slave address match detection monitor

In the slave mode, the AAS (Bit2 in SBISR) is set to " 1 " when the received data is "GENERAL CALL" or the received data matches the slave address setting by I2CAR with an address recognition mode ( $\mathrm{ALS}=0$ ).

When a serial bus interface circuit operates in the free data format ( $\mathrm{ALS}=1$ ), the AAS is set to " 1 " after receiving the first 1 -word of data.

The AAS is cleared to " 0 " by writing data to the SBIDBR or reading data from the SBIDBR.
(12) GENERAL CALL detection monitor

The AD0 (Bit1 in SBISR) is set to " 1 " when all 8 -bit received data is " 0 " immediately after a start condition in a slave mode. The AD0 is cleared to " 0 " when a start or stop condition is detected on a bus.
(13) Last received bit monitor

The SDA value stored at the rising edge of the SCL is set to the LRB (Bit0 in SBISRB). In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the LRB.

### 2.9.8 Data Transfer of $I^{2} \mathrm{C}$ Bus

(1) Device initialization

For initialization of device, set the ACK in SBICRA to " 1 " and the BC to " 000 ". Specify the data length to 8 bits to count clocks for an acknowledge signal. Set a transfer frequency to the SCK in SBICRA.

Next, set the slave address to the SA in I2CAR and clear the ALS to "0" to set an addressing format.
After confirming that the serial bus interface pin is high level, for specifying the default setting to a slave receiver mode, clear " 0 " to the MST, TRX and BB in SBICRB, set " 1 " to the PIN, " 10 " to the SBIM, and " 00 " to bits SWRST1 and SWRST0.

Note: The initialization of a serial bus interface circuit must be complete within the time from all devices which are connected to a bus have initialized to and device does not generate a start condition. If not, the data can not be received correctly because the other device starts transferring before an end of the initialization of a serial bus interface circuit.
(2) Start condition and slave address generation

Confirm a bus free status (when $\mathrm{BB}=0$ ).
Set the ACK to " 1 " and specify a slave address and a direction bit to be transmitted to the SBIDBR.
By writing " 1 " to the MST, TRX, BB and PIN, the start condition is generated on a bus and then, the slave address and the direction bit which are set to the SBIDBR are output. An INTSBI interrupt request occurs at the 9th falling edge of a SCL clock cycle, and the PIN is cleared to " 0 ". The SCL pin is pulled down to the low level while the PIN is " 0 ". When an interrupt request occurs the TRX changes by the hardware according to the direction bits only when an acknowledge signal is returned from the slave device.

Note 1: Do not write a slave address to be output to the SBIDBR while data is transferred. If data is written to the SBIDBR, data to been outputting may be destroyed.

Note 2:The bus free must be confirmed by software within $98.0 \mu \mathrm{~s}$ (the shortest transmitting time according to the $I^{2} C$ bus standard) after setting of the slave address to be output. Only when the bus free is confirmed, set " 1 " to the MST, TRX, BB, and PIN doesn't finish within $98.0 \mu \mathrm{~s}$, the other masters may start the transferring and the slave address data written in SBIDBR may be broken.


Figure 2.9.13 Start Condition Generation and Slave Address Transfer
(3) 1-word data transfer

Check the MST by the INTSBI interrupt process after an 1-word data transfer is completed, and determine whether the mode is a master or slave.
a. When the MST is " 1 " (Master mode)

Check the TRX and determine whether the mode is a transmitter or receiver.

1. When the TRX is " 1 " (Transmitter mode)

Test the LRB. When the LRB is " 1 ", a receiver does not request data. Implement the process to generate a stop condition (Described later) and terminate data transfer.

When the LRB is " 0 ", the receiver requests next data. When the next transmitted data is other than 8 bits, set the BC, set the ACK to " 1 ", and write the transmitted data to the SBIDBR. After writing the data, the PIN becomes " 1 ", a serial clock pulse is generated for transferring a next 1 word of data from the SCL pin, and then the 1 -word data is transmitted. After the data is transmitted, and an INTSBI interrupt request occurs. The PIN become " 0 " and the SCL pin is set to low level. If the data to be transferred is more than one word in length, repeat the procedure from the LRB test above.


Figure 2.9.14 Example of when $\mathrm{BC}=" 000$ ", $\mathrm{ACK}=" 1$ "
2. When the TRX is " 0 " (Receiver mode)

When the next transmitted data is other than of 8 bits, set the BC again. Set the ACK to " 1 " and read the received data from the SBIDBR (Reading data is undefined immediately after a slave address is sent). After the data is read, the PIN becomes " 1 ". A serial bus interface circuit outputs a serial clock pulse to the SCL to transfer next 1 word of data and sets the SDA pin to "0" at the acknowledge signal timing.

An INTSBI interrupt request occurs and the PIN becomes " 0 ". Then a serial bus interface circuit outputs a clock pulse for 1 word of data transfer and the acknowledge signal each time that received data is read from the SBIDBR.


Figure 2.9.15 Example of when $\mathrm{BC}=$ " 000 ", $\mathrm{ACK}=$ " 1 "

To make the transmitter terminate transmit, clear the ACK to "0" before reading data which is 1 word before the last data to be received. A serial bus interface circuit does not generate a clock pulse for the acknowledge signal by clearing ACK. In the interrupt routine of end of transmission, when the BC is set to " 001 " and read the data, PIN is set to " 1 " and generates a clock pulse for a 1-bit data transfer. In this case, since the master device is a receiver, the SDA line on a bus keeps the high level. The transmitter receives the high-level signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete.

After 1-bit data is received and an interrupt request has occurred, generates the stop condition to terminate data transter.


Figure 2.9.16 Termination of Data Transfer in Master Receiver Mode
b. When the MST is " 0 " (Slave mode)

In the slave mode, a serial bus interface circuit operates either in normal slave mode or in slave mode after losing arbitration.

In the slave mode, the conditions of generating INTSBI are follows:

- When the received slave address matches to the value set by the I2CAR
- When a "GENERAL CALL" is received
- At the end of transferring or receiving after matching of slave address or receiving of "GENERAL CALL"
A serial bus interface circuit changes to a slave mode if arbitration is lost in the master mode. And an INTSBI interrupt request occurs when word data transfer terminates after losing arbitration. The behavior of INTSBI and PIN after losing arbitration are shown in Table 2.9.2.

Table 2.9.2 The Behavior of INTSBI and PIN after Losing Arbitration

|  | When the arbitration occurs during transmission <br> of slave address as a master | When the arbitration occurs during transmission <br> of data as a master transmit mode |
| :--- | :--- | :--- |
| INTSBI | INTSIB is generated at the terminatin of word data. |  |
| PIN | When the slave address matches the value set by <br> I2CAR, the PIN is cleared to "0" by generating of <br> INTSBI. When the slave address doesn't match <br> the value set by I2CAR, the PIN keeps "1". | PIN keeps "1". |

Check the AL (Bit3 in the SBISR), the TRX (Bit6 in the SBISR), the AAS (Bit2 in the SBISR), and the AD0 (Bit1 in the SBISR) and implements processes according to conditions listed in Table 2.9.3.

Table 2.9.3 Operation in the Slave Mode

| TRX | AL | AAS | AD0 | Conditions | Process |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | A serial bus interface circuit loses arbitration when transmitting a slave address. And receives a slave address of which the value of the direction bit sent from another master is " 1 ". | Set the number of bits in 1 word to the BC and write transmitted data to the SBIDBR. |
|  | 0 | 1 | 0 | In the slave receiver mode, a serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is " 1 ". |  |
|  |  | 0 | 0 | In the slave transmitter mode, 1-word data is transmitted. | Test the LRB. If the LRB is set to " 1 ", set the PIN to "1" since the receiver does not request next data. Then, clear the TRX to "0" release the bus. If the LRB is set to " 0 ", set the number of bits in 1 word to the $B C$ and write transmitted data to the SBIDBR since the receiver requests next data. |
| 0 | 1 | 1 | 1/0 | A serial bus interface circuit loses arbitration when transmitting a slave address. And receives a slave address of which the value of the direction bit sent from another master is " 0 " or receives a "GENERAL CALL". | Read the SBIDBR for setting the PIN to "1" (Reading dummy data) or write " 1 " to the PIN. |
|  |  | 0 | 0 | A serial bus interface circuit loses arbitration when transmitting a slave address or data. And terminates transferring word data. | A serial bus interface circuit is changed to slave mode. To clear $A L$ to " 0 ", read the SBIDBR or write the data to SBIDBR. |
|  | 0 | 1 | 1/0 | In the slave receiver mode, a serial bus interface circuit receives a slave address of which the value of the direction bit sent from the master is "0" or receives "GENERAL CALL". | Read the SBIDBR for setting the PIN to " 1 " (Reading dummy data) or write "1" to the PIN. |
|  |  | 0 | 1/0 | In the slave receiver mode, a serial bus interface circuit terminates receiving of 1 -word data. | Set the number of bits in 1 word to the $B C$ and read received data from the SBIDBR. |

Note: In the slave mode, if the slave address set in I2CAR is "00000000B", the TRX changes to " 1 " by receiving the start byte data " 00000001 B ".
(4) Stop condition generation

When the BB is " 1 ", a sequence of generating a stop condition is started by setting " 1 " to the MST, TRX, and PIN, and clear " 0 " to the BB. Do not modify the contents of the MST, TRX, BB, PIN until a stop condition is generated on a bus.

When a SCL line on a bus is pulled down by other devices, a serial bus interface circuit generates a stop condition after they release a SCL line.


Figure 2.9.17 Stop Condition Generation
(5) Restart

Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart a serial bus interface circuit.

Clear " 0 " to the MST, TRX and BB and set " 1 " to the PIN. The SDA pin retains the high level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Test the BB until it becomes " 0 " to check that the SCL pin a serial bus interface circuit is released. Test the LRB until it becomes " 1 " to check that the SCL line on a bus is not pulled down to the low level by other devices. After confirming that a bus stays in a free state, generate a start condition with procedure (2).

In order to meet setup time when restarting, take at least $4.7 \mu \mathrm{~s}$ of waiting time by software from the time of restarting to confirm that a bus is free until the time to generate a start condition.

Note: When restarting after receiving in master receiver mode, because the divice doesn't send an acknowledgement as a last data, the level of SCL line can not be conrirmied by reading LRB. Therefore, confirm the status of SCL line by reading P5PRD register.


Figure 2.9.18 Timing Diagram when Restarting

### 2.9.9 Clocked-synchronous 8-Bit SIO Mode Control

The following registers are used to control the serial bus interface (SBI) and monitor the operation in the clocked-synchronous 8-bit SIO mode.


Note 1: *: Don't care
Note 2: Switch a mode to port after data transfer is complete.
Note 3: Switch a mode to $I^{2} \mathrm{C}$ bus mode or clock synchronous 8 -bit SIO mode after confirming that the port is high level.
Note 4: SBICRB is a write-only register and cannot be used with any of read-modify-write instructions such as bit manipulation, etc.
Note 5: Clear bit7 to 5 in SBICRB to " 0 ", and set bit4 to " 1 ".
Note 6: When the SWRST (Bit1, 0 in SBICRB) is written to " 01 ", " 10 ", software reset is occurred.
This time, control the serial bus interface and monitor the operation status registers except the SBIM (Bit3, 2 in SBICRB) and the CHS (Bit6 in PMPXCR) are reseted.
Control the serial bus interface and monitor the operation status registers are SBICRA, SBICRB, SBIDBR, I2CAR, SBISRA, SBISRB, SCCRA, SCCRB and SCSR.
Figure 2.9.19 Control Register/Data Buffer Register/Status Register in SIO Mode (1)


Serial Bus Interface Status Register B
SBISRB
$(00023 H)$

| SIOF | Serial transfer operating status <br> monitor | 0: Transfer terminated <br> 1: Transfer in process | Read <br> only |
| :---: | :--- | :--- | :---: |
| SEF | Shift operating status monitor | 0: Shift operation terminated <br> 1: Shift operation in process |  |

Note: Set bit7 to 4, bit1 and bit0 in SBISRB to "1".
Figure 2.9.20 Control Register/Data Buffer Register/Status Register in SIO Mode (2)
(1) Serial clock
a. Clock source

The SCK (Bits 2 to 0 in SBICRA) is used to select the following functions.

1. Internal clock

In an internal clock mode, any of seven frequencies can be selected. The serial clock is output to the outside on the $\overline{S C K}$ pin. The $\overline{\text { SCK }}$ pin becomes a high level when data transfer starts. When writing (in the transmit mode) or reading (in the receive mode) data cannot follow the serial clock rate, an automatic-wait function is executed to stop the serial clock automatically and hold the next shift operation until reading or writing is complete.


Figure 2.9.21 Automatic-wait Function
2. External $(\mathrm{SCK}=" 111$ ")

An external clock supplied to the $\overline{\mathrm{SCK}}$ pin is used as the serial clock. In order to ensure shift operation, a pulse width of at least 2 -machine cycles is required for both high and low levels in the serial clock. The maximum data transfer frequency is 1 MHz ( $\mathrm{fc}=16.0 \mathrm{MHz}$ ).


Figure 2.9.22 The Maximum Data Transfer Frequency in The External Clock Input
b. Shift edge

The leading edge is used to transmit data, and the trailing edge is used to receive data.

1. Leading edge

Data is shifted on the leading edge of the serial clock (at a falling edge of the $\overline{\text { SCK }}$ pin input/output).
2. Trailing edge

Data is shifted on the trailing edge of the serial clock (at a rising edge of the SCK pin input/output).


Figure 2.9.23 Shift Edge
(2) Transfer mode

The SIOM (Bits 5 and 4 in SBICRA) is used to select a transmit, receive, or transmit/receive mode.
a. 8-bit transmit mode

Set a control register to a transmit mode and write transmit data to the SBIDBR.

After the transmit data is written, set the SIOS to " 1 " to start data transfer. The transmitted data is transferred from the SBIDBR to the shift register and output to the SO pin in synchronous with the serial clock, starting from the least significant bit (LSB). When the transmit data is transferred to the shift register, the SBIDBR becomes empty. The INTSBI (Buffer empty) interrupt request is generated to request new data.

When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8 -bit data is transmitted. When transmit new data is written, automatic-wait function is canceled.

When the external clock is used, data should be written to the SBIDBR before new data is shifted.

The SO pin is " 1 " from the time transmission starts until the first data bit is sent. When SIOF becomes " 0 ", the shift register is cleared. So, output of an undefined value is not prevented at the start of the next transmission.

The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to the SBIDBR by the interrupt service program.

Transmitting data is ended by cleaning the SIOS to " 0 " by the buffer empty interrupt service program or setting the SIOINH to " 1 ". When the SIOS is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the SIOF (Bit3 in the SBISRB) to be sensed. The SIOF is cleared to " 0 " when transmitting is complete. When the SIOINH is set, transmitting data stops. The SIOF turns "0".

When the external clock is used, it is also necessary to clear the SIOS to " 0 " before new data is shifted; otherwise, dummy data is transmitted and operation ends.


Figure 2.9.24 Transfer Mode


Figure 2.9.25 Transmitted Data Hold Time at End of Transmit
b. 8-bit receive mode

Set a control register to a receive mode and the SIOS to " 1 " for switching to a receive mode.

Data is received from the SI pin to the shift register in synchronous with the serial clock, starting from the least significant bit (LSB). When the 8 -bit data is received, the data is transferred from the shift register to the SBIDBR. The INTSBI (Buffer full) interrupt request is generated to request of reading the received data. The data is read from the SBIDBR by the interrupt service program.

When the external clock is used, since shift operation is synchronized with the clock pulse provided externally, the received data should be read from SBIDBR before next serial clock is input. If the received data is not read, further data to be received is canceled.

When the internal clock is used, the automatic wait function is executed until received data is read from SBIDBR.

The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read.

Received data disappears if this data is not completely read before reception of the next data terminates. In this case, the next data received is read.

Receiving data is ended by clearing the SIOS to " 0 " by the buffer full interrupt service program or setting the SIOINH to " 1 ". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm if data is surely received by the program, set the SIOF (Bit3 in SBIDBR) to be sensed. The SIOF is cleared to " 0 " when receiving is complete. After confirming that receiving has ended, the last data is read. When the SIOINH is set, receiving data stops. The SIOF turns " 0 " (the received data becomes invalid, therefore no need to read it).

Note: When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, receiving data is concluded by clearing the SIOS to " 0 ", read the last data, and then switch the mode.


Figure 2.9.26 Receive Mode (Example: Internal clock)
c. 8-bit transmit/receive mode

Set a control register to a transmit/receive mode and write data to the SBIDBR. After the data is written, set the SIOS to " 1 " to start transmitting/receiving. When transmitting, the data is output from the SO pin on the leading edges in synchronous with the serial clock, starting from the least significant bit (LSB). When receiving, the data is input to the SI pin on the trailing edges of the serial clock. 8-bit data is transferred from the shift register to the SBIDBR, and the INTSBI interrupt request occurs. The interrupt service program reads the received data from the data buffer register and writes data to be transmitted. The SBIDBR is used for both transmitting and receiving. Transmitted data should always be written after received data is read.

When the internal clock is used, automatic-wait function is initiated until received data is read and next data is written.

When the external clock is used, since the shift operation is synchronized with the external clock, received data is read and transmitted data is written before new shift operation is executed. The maximum transfer speed when the external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when received data is read and transmitted data is written.
When transmission starts, a value which is the same as the last bit of previously transmitted data is output from the time SIOF is set to " 1 " until the falling edge of SCK occurs.

Transmitting/receiving data is ended by cleaning the SIOS to " 0 " by the INTSBI interrupt service program or setting the SIONH to " 1 ". When the SIOS is cleared, received data is transferred to the SBIDBR in complete blocks. The transmit/receive mode ends when the transfer is complete. In order to confirm if data is surely transmitted/received by the program, set the SIOF (bit 3 in SBISRB) to be sensed. The SIOF becomes " 0 " after transmitting/receiving is complete. When the SIONH is set, transmitting/receiving data stops. The SIOF turns " 0 ".

Note: When the transfer mode is switched, the SBIDBR contents are lost. In case that the mode needs to be switched, conclude transmitting/receiving data by clearing the SIOS to " 0 ", read the last data, and then switch the transfer mode.


Figure 2.9.27 Transmit/Receive Mode (Example: Internal clock)


Figure 2.9.28 Transmitted Data Hold Time at End of Transmit/Receive

### 2.10 Remote Control Signal Preprocessor/External Interrupt 3 Input Pin

The remote control signal waveform can be determined by inputting the remote control signal waveform from which the carrier wave was eliminated by the receive circuit to P30 (INT3/RXIN) pin. When the remote control signal preprocessor/external interrupt 3 pin is also used as the P30 port, set the P30 port output latch to " 1 ". When it is not used as the remote control signal preprocessor/external interrupt 3 input pin, it can be used for normal port.

### 2.10.1 Configuration



Figure 2.10.1 Remote Control Signal Preprocessor

### 2.10.2 Remote Control Signal Preprocessor Control

When the remote control signal preprocessor is used, operating states are controlled and monitored by the following registers. Interrupt requests also use the remote control signal preprocessor/external interrupt 3 input pin.

- Remote control receive control register 1 (RXCR1)
- Remote control receive control register 2 (RXCR2)
- Remote control receive counter register (RXCTR)
- Remote control receive data buffer register (RXDBR)
- Remote control receive status register (RXSR)

When this pin is used for the external interrupt 3 input, set EINT in RXCR1 to other than "11".

Remote Control Receive Control Register 1


Note 1: fc: High-frequency clock [Hz]
Note 2: After reset, RPOLS do not change the set value in the receiving remote control signal. For setting interrupt edge and measurement data, use EINT and RMM.

Remote Control Receive Control Register 2


Note 1: fc: High-frequency clock [Hz]
Note 2: When an interrupt source is set for rising/falling edge, low and high widths are forcibly measured separately.
Note 3: Set CREGA (OH to FH) before EINT sets to 8-bit receive end.

Figure 2.10.2 Remote Control Receive Control Register 1, 2

| Remote Control Receive Counter Register |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RXCTR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Read only <br> (Initial value: 0000 0000) |  |
| Remote Control Receive Data Buffer Register |  |  |  |  |  |  |  |  |  |  |
| RXDBR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Read only (Initial value: 0000 0000) |  |
| Remote Control Receive Status Register |  |  |  |  |  |  |  |  |  |  |
| RXSR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Read only (Initial value: 0000 *000) |  |
| (00FECH) | RBCTM |  |  |  |  | OVFF | SRM | RNCM |  |  |
|  | RBCTM | Receive bit counter value monitor |  |  |  |  |  |  |  | Read only |
|  | OVFF | 8-bit up counter overflow flag |  |  |  | 0: No overflow <br> 1: Overflow |  |  |  |  |
|  | SRM | Data buffer register input monitor |  |  |  | 0: Upper 4 bits of 8 bit up counter $<$ CREGA <br> 1: Upper 4 bits of 8 bit up counter $\geq$ CREGA |  |  |  |  |
|  | RNCM | Remote control signal monitor after passing through noise canceler |  |  |  |  |  |  |  |  |
| *: Don't care |  |  |  |  |  |  |  |  |  |  |

Figure 2.10.3 Remote Control Receive Counter Register, Data Buffer Register, Status Register

Table 2.10.1 Combination of Interrupt Source and Measurement Mode

| RPOLS | EINT | RMM | Interrupt Source | Measurement Mode |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 00 | 00 <br> 10 <br> 11 |  |  |
|  | 01 | 01 <br> 10 <br> 11 |  |  |
|  | 10 | - | $\uparrow \downarrow$ | $\rightarrow \longleftrightarrow \longleftrightarrow \longleftrightarrow$ |
|  | 11 | $\begin{aligned} & 00 \\ & 10 \end{aligned}$ | Receive end |  |
| 1 | 00 | 00 10 11 |  |  |
|  | 01 | 01 <br> 10 <br> 11 | $\uparrow$ |  |
|  | 10 | - |  | $\rightarrow \longleftrightarrow \longleftrightarrow$ |
|  | 11 | $\begin{aligned} & 00 \\ & 10 \end{aligned}$ | Receive end |  |

### 2.10.3 Noise Elimination Time Setting

The remote control receive circuit has a noise canceler. By setting RNC in RXCR1, input signals shorter than the fixed time can be eliminated as noise.

Table 2.10.2 Noise Elimination Time Setting (fc = 16 MHz )

| RNC | Minimum Signal Pulse Width |  | Maximum Noise Width to be Eliminated |  |
| :---: | :---: | :---: | :---: | :---: |
| 000 |  |  |  |  |
| 001 | $\left(2^{5}+5\right) / \mathrm{fc}$ | (2.31 $\mu \mathrm{s}$ ) | ( $\left.2^{2} \times 7-1\right) / \mathrm{fc}$ | (1.69 $\mu \mathrm{s}$ ) |
| 010 | $\left(2^{8}+5\right) / \mathrm{fc}$ | (16.31 $\mu \mathrm{S}$ ) | $\left(2^{5} \times 7-1\right) / f \mathrm{c}$ | (13.88 $\mu \mathrm{s}$ ) |
| 011 | $\left(2^{9}+5\right) / \mathrm{fc}$ | (32.31 $\mu \mathrm{S}$ ) | $\left(2^{6} \times 7-1\right) / \mathrm{fc}$ | (27.88 $\mu \mathrm{s}$ ) |
| 100 | $\left(2^{10}+5\right)$ /fc | (64.31 $\mu \mathrm{S}$ ) | $\left(2^{7} \times 7-1\right) / \mathrm{fc}$ | (55.88 $\mu \mathrm{s}$ ) |
| 101 | $\left(2^{11}+5\right) / f \mathrm{c}$ | $(128.3 \mu \mathrm{~S})$ | $\left(2^{8} \times 7-1\right) / \mathrm{fc}$ | (111.9 $\mu \mathrm{s}$ ) |
| 110 | $\left(2^{13}+5\right)$ /fc | (512.3 $\mu \mathrm{s}$ ) | $\left(2^{10} \times 7-1\right) / \mathrm{fc}$ | (447.9 $\mu \mathrm{s}$ ) |
| 111 | $\left(2^{14}+5\right)$ /fc | $(1.024 \mathrm{~ms})$ | $\left(2^{11} \times 7-1\right) / \mathrm{fc}$ | (895.9 $\mu \mathrm{s}$ ) |

### 2.10.4 Operation

(1) Interrupts at rising, falling, or rising/falling edge, and measurement modes

First set EINT and RMM. Next, set RCS to " 1 "; the 8 -bit up counter is counted up by the internal clock. After measurement, the 8 -bit up counter value is saved in RXCTR. Then, the 8 -bit up counter is cleared, an INT3 request is generated, and the 8 -bit up counter resumes counting.

If the 8 -bit up counter overflows (FFH) before measurement is completed, an INT3 request is generated and the overflow flag (OVFF) is set to " 1 ". Then, the 8 -bit up counter is cleared. An overflow can be detected by reading OVFF by the interrupt processing. To restart the 8 -bit up counter, set RCS to " 1 ".

Setting RCS to " 1 " zero clears OVFF.


Figure 2.10.4 Rising Edge Interrupt Timing Chart (RPOLS = 0)


Figure 2.10.5 Falling Edge Interrupt Timing Chart (RPOLS $=0$ )


Figure 2.10.6 Rising/Falling Edge Interrupt Timing Chart
(2) 8-bit receive end interrupts and measurement modes

By determining one-cycle remote control signal as one-bit data set to " 0 " or one-pulse width remote control signal as one-bit data set to " 1 ", an INT3 request is generated after 8 -bit data is received. When " 0 " is determined, this means the upper four bits in the 8 -bit up counter have not reached the CREGA value. When " 1 " is determined, this means the upper four bits in the 8-bit up counter have reached or exceeded the CREGA value. The 8 -bit up counter value is saved in RXCTR after one bit is determined. The determined data is saved, bit by bit, in RXDBR at the rising edge of the remote control signal (when RPOLS $=1$, falling edge). The number of bits saved in RXDBR is counted by the receive bit counter and saved in RBCTM. RBCTM is set to "0001B" at the rising edge of the input (when RPOLS $=1$, falling edge) after the INT3 request is generated.

*: Valid only when 8 bits are received.
Figure 2.10.7 Overflow Interrupt Timing Chart


Figure 2.10.8 8-Bit Receive End Interrupt Timing Chart (PROLS $=0$ )

Table 2.10.3 Count Clock for Remote Control Preprocessor Circuit (at fc $=16 \mathrm{MHz}$ )

| Count Clock (RCCK) | Resolution $[\mu \mathrm{s}]$ | Maximum Setting Time $[\mathrm{ms}]$ |
| :---: | :---: | :---: |
| 00 | 4 | 1.024 |
| 01 | 16 | 4.096 |
| 10 | 64 | 16.38 |
| 11 | 256 | 65.53 |

### 2.11 8-Bit AD Converter (ADC)

The TMP88CS38B/CM38B/CP38B has a 8-bit successive approximation type AD converter.

### 2.11.1 Configuration

Figure 2.11 .1 shows the circuit configuration of the AD converter.
The AD converter includes control registers ADCCRA and ADCCRB, conversion result registers ADCDR1 and ADCDR2, a DA converter, a sample hold circuit, a comparator, and sequential transducer circuit.

To use P5 and P6 as analog inputs, clear the output latch for P5 and P6 to " 0 ". Also, clear the input/output control registers (P5CR1 and P6CR) to " 0 ".


Figure 2.11.1 AD Converter (ADC)

### 2.11.2 Control Register

The following register are used for AD converter.

- AD converter control register 1 (ADCCRA)
- AD converter control register 2 (ADCCRB)
- AD conversion result register (ADCDR1/ADCDR2)
(1) AD converter control register 1 (ADCCRA)

ADCCRA control AD conversion start, AD operation mode select, analog input control and analog input channel select.
(2) AD converter control register 2 (ADCCRB)

ADCCRB control AD conversion time select.
(3) AD conversion result register (ADCDR1)

AD conversion result is stored after end of conversion.
(4) AD conversion result register (ADCDR2)

For monitoring status of conversion.
Figure 2.11 .2 and Figure 2.11 .3 show AD converter control register.


Note 1: Select analog input when AD converter stops.
Note 2: When the analog input is all use disabling, the AINDS should be set to " 1 ".
Note 3: During conversion, do not perform output instruction to maintain a precision for all of the pins.
And port near to analog input, do not input intense signaling of change.
Note 4: The ADRS is automatically cleared to " 0 " after starting conversion.
Note 5: Always set bit3 in ADCCRA to "0".
Note 6: Do not set ADRS (Bit7 in ADCCRA) to "1" during AD conversion. Reset it after confirming with EOCF (Bit5 in ADCDR2) that the conversion is completed or after generation an interrupt signal (INTADC) (by the interrupt processing routine or the like).
Note 7 In the trigger mode, the system does not accept the second and subsequent triggers after accepting the first trigger for starting AD conversion. To restart AD conversion by a trigger, set AMD (Bits 6 and 5 in ADCCRA) to " 00 " and then put the system in trigger start mode again (with AMD = "10").
Note 8: When the system enters STOP mode, AD converter control register 1 (ADCCRA) is initialized. Reset this register after the system reenters NORMAL mode.

## AD Converter Control Register 2



Note 1: Do not use setting except the above liset.
Note 2: Set conversion time by analog reference voltage ( $\mathrm{V}_{\mathrm{DD}}$ ) as follows.

$$
\mathrm{V}_{\mathrm{DD}}=4.5 \text { to } 5.5 \mathrm{~V}(15.6 \mu \text { or more })
$$

Note 3: Always set bit0 and bit5 in ADCCRB to " 0 " and set bit4 in ADCCRB to " 1 ".
Note 4: When a read instruction for ADCCRB, bit6 to 7 in ADCCRB read in as undefined data.
Note 5: fc: High-frequency clock [Hz]
Note 6: When the system enters STOP mode, AD converter control register 2 (ADCCRA) is initialized. Reset this register after the system reenters NORMAL mode.

Figure 2.11.2 AD Converter Control Register

| AD Conversion Result Register |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADCDR1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (Initial value: 0000 0000) |  |
| (00031H) | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | AD01 | AD00 |  |  |
| ADCDR2 | 7 |  | 5 |  | 3 | 10 |  |  | (Initial value: **00 ****) |  |
| (00032H) |  |  | EOCF | ADBF |  | - |  | - |  |  |
|  | EOCF | AD conversion end flag |  |  | $\begin{aligned} & 0: \\ & 1: \end{aligned}$ | Under conversion or before conversion End of conversion |  |  |  | Read only |
|  | ADBF | AD conveersion busy flag |  |  | 0 $1:$ 1 | During stop of AD conversion During AD conversion |  |  |  |  |

Note 1: The EOCF is cleared to " 0 " when reading the ADCDR1.
Therefore, the AD conversion result should be read to ADCDR1 more first than ADCDR2.
Note 2: ADBR is set to " 1 " by starting AD conversion and cleared to " 0 " by end of AD conversion. Additionally, ADBF is cleared to " 0 " by setting AMD $=$ " 00 " in ADCCR2 or entering to the STOP mode.

Figure 2.11.3 AD Converter Result Register

### 2.11.3 AD Converter Operation

The high side of an analog reference voltage is applied to VDD, and the low side is applied to VSS pin. Dividing a reference voltage between VDD and VSS to the voltage corresponding to a bit by a rudder resistance and comparing it with the analog input voltage converts the AD .

Table 2.11.1 AD Converter Operation Mode

| Mode | Function |
| :--- | :--- |
| AD converter disable mode | AD converter stop mode. This mode is always used to change modes. |
| Software start mode | Single AD conversion of 1 channel which specifies input. |
| Trigger start mode | Single AD conversion of 1 channel which specifies input (AD8TRG) from <br> Key-on wakeup circuit as a trigger. |

### 2.11.4 Interrupt

Interrupt request signal occur at the timing when the EOCF bit is set to " 1 ".

### 2.11.5 AD Converter Operation Modes

When the MCU places in the STOP mode during the AD conversion, the conversion is stopped and the ADCDR2 content becomes indefinite. After returning from the STOP mode, the EOCF and INTADC does not occur. Therefore, the AD conversion must be restarted after returning from the STOP mode.


Figure 2.11.4 AD Conversion Timing chart
(1) AD conversion in STOP mode

When the $A D$ converter stop mode is specified during $A D$ conversion, the $A D$ conversion is stopped immediately. The AD conversion is not implemented, so the undefined value is not written to the $A D$ conversion result register. The AD conversion start commands which occur is the AD converter stop mode are ignored.

This mode is automatically selected by reset.
This mode is used to change the AD converter operation mode.
(2) Single mode

When the AMD (Bit6, 5 to in ADCCRA) set to " 01 ", the AD conversion signal mode
This mode does AD conversion of single channel, and conversion result is stored in ADCDR1. The EOCF (Bit5 in ADCDR2) is set to " 1 " at end of one conversion, and an intcrrupt request signal occurs. The EOCF is cleared to " 0 " by reading the AD conversion registers.

But when the AD conversion is restarted before the ADCDR is read, the EOCF is cleared to " 0 " and the last AD conversion result is maintained till next conversion end.

Do not set ADRS (Bit7 in ADCCRA) during AD conversion. Again set it after confirming with EOCF (Bit5 in ADCDR2) that the conversion is completed or after generating an interrupt signal (INTADC) (by the interrupt processing routine or the like).


Figure 2.11.5 Single Mode

Example: The AD conversion starts after $19.5 \mu \mathrm{~s}$ (at $\mathrm{fc}=16 \mathrm{MHz}$ ) and AIN4 pin are selected as the conversion time and the analog input channel. Confirming the EOCF, the converted value is read out, and the 8 bits data is stored to address 009EH in RAM. The operation mode is a signal mode.
;AIN SELECT
LD (P5), 00000000B
LD (P5CR1), 00000000B
LD (P6), 00000000B
LD (P6CR), 00000000B
LD (ADCCRA), 00100100B ; Selects AIN4, selects the software start mode
LD (ADCCRB), 00011000B ; Selects the conversion time and the operation mode

(3) Trigger start mode

The AD conversion of a specified single channel is executed when input (AD8TRG) from Key-on wakeup circuit is set as trigger, the conversion result is stored in the ADCDR1.

The EOCF (Bit5 in ADCDR2) is set to " 1 " at end of one conversion, and an interrupt request signal occurs.

It needs to be set the STOP mode by bit5 to 6 in ADCCRA before the AD conversion is executed again.

### 2.11.6 Analog Input Voltage and AD Conversion Result

The analog input voltage is corresponded to the 8 -bit digital value converted by the AD as shown in Figure 2.11.6.


Figure 2.11.6 Analog Input Voltage and AD Conversion Result (typ.)

### 2.11.7 STOP Modes during AD Conversion

When standby mode (STOP mode) is entered forcibly during AD conversion, the AD convert operation is suspended and the AD converter is initialized. (ADCCRA and ADCCRB are initialized to initial value.) Also, the conversion result is indeterminate. (Conversion results up to the previous operation are cleared, so be sure to read the conversion results before entering standby mode.) When restored from standby mode, AD conversion is not automatically restarted, so it is necessary to restart AD conversion after setting ADCCRA and ADCCRB. Note that since the analog reference voltage is automatically disconnected, there is no possibility of current flowing into the analog reference voltage.

### 2.11.8 Notice of AD Converter

(1) Analog input voltage range

Voltage range of analog input (AIN0 to AIN5) must be forced from VSS to VDD. If input voltage of which out of range is forced to analog input pin, AD conversion result to unknown. Also, this cause other analog input pin unstable.
(2) I/O port with analog input

Analog input pins (AIN0 to AIN5) are also I/O port. During AD conversion using any analog input pin, don't operate other I/O port with analog input. Because, AD accuracy would be worse. Also, other electrically swinging port without analog input may cause noise to near analog input pin.
(3) Reduce to noise

Figure 2.11.7 is shown as internal equivalent circuit of analog input pin.
Increasing output impedance of analog input supply, cause noise or other non-good condition.
Therefore, output impedance of analog input supply must be less than $5 \mathrm{k} \Omega$.
And we recommend to connect capacitance to analog input pin.


Figure 2.11.7 Analog Input Equivalent Circuit and Analog Input Pin

### 2.12 Key-on Wakeup

In this MCU the IDLE mode is also released by low active port inputs. The low input voltage is regulated higher than the other normal ports. Therefore the ports can be enabled by analog input level.

### 2.12.1 Configuration



Figure 2.12.1 Key-on Wakeup Control Circuit

### 2.12.2 Control

P53 to P56 and P60, P61 ports can be controlled by IDLE control register (IDLECR).
It can be configured as enable/disable in one-bit unit. When those pins are used by IDLE mode release, those pins must be set input mode (P5CR1, P5, P6CR, P6, ADCCRA).

IDLE mode is controlled by system control register 2 (SYSCR2) and maskable interrupts. After the individual enable flag (EF5) is set to " 1 ", the IDLE mode must starts. When enabled port input generates INTKWU interrupt, the IDLE mode is released. Low level input voltage in those ports is regulated to less than VDD $\times 0.65(\mathrm{~V})$.

IDLE port monitorring register (IDLEIN) can be used to check state of ports.
INTADEN can enable to generate AD8TRG, which is used as trigger of AD converter trigger start mode.

Noise reject circuit eliminate noise, which is less than $24 \mu$ s period.

| IDLE Control Register |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDLECR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| (00FDOH) | INTAD EN | * | IDLE5 EN | $\begin{gathered} \text { IDLE4 } \\ \text { EN } \end{gathered}$ | IDLE3 EN | $\begin{gathered} \text { IDLE2 } \\ \text { EN } \end{gathered}$ | $\begin{gathered} \text { IDLE1 } \\ \text { EN } \end{gathered}$ | $\begin{gathered} \text { IDLEO } \\ \text { EN } \end{gathered}$ | (Initial value: 0*00 0000) |  |
|  | INTADEN | Generation of $\overline{\text { AD8TRG }}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  | Write only |
|  | IDLE5EN | Release IDLE mode by $\overline{\mathrm{KWU5}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | IDLE4EN | Release IDLE mode by $\overline{\mathrm{KWU4}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | IDLE3EN | Release IDLE mode by $\overline{\mathrm{KWU3}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | IDLE2EN | Release IDLE mode by $\overline{\mathrm{KWU2}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | IDLE1EN | Release IDLE mode by $\overline{\mathrm{KWU1}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | IDLE0EN | Release IDLE mode by $\overline{\mathrm{KWUO}}$ |  |  |  | 0: Disable <br> 1: Enable |  |  |  |  |
|  | *: Don't care |  |  |  |  |  |  |  |  |  |
| IDLE Port Monitoring Register |  |  |  |  |  |  |  |  |  |  |
| IDLEIN | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (Initial value: **00 0000) |  |
| (00FDOH) | * | * | $\begin{aligned} & \text { IDLE5 } \\ & \text { IN } \end{aligned}$ | $\begin{aligned} & \text { IDLE4 } \\ & \text { IN } \end{aligned}$ | $\begin{aligned} & \text { IDLE3 } \\ & \text { IN } \end{aligned}$ | $\begin{aligned} & \text { IDLE2 } \\ & \text { IN } \end{aligned}$ | $\begin{aligned} & \text { IDLE1 } \\ & \text { IN } \end{aligned}$ | $\begin{aligned} & \text { IDLEO } \\ & \text { IN } \end{aligned}$ |  |  |  |
|  | IDLE5IN | Input level of $\overline{\text { KWU5 }}$ |  |  |  | 0: "0" detect <br> 1: "1" detect |  |  |  | Read only |
|  | IDLE4IN | Input level of $\overline{\text { KWU4 }}$ |  |  |  | 0: "0" detect <br> 1: "1" detect |  |  |  |  |
|  | IDLE3IN | Input level of $\overline{\text { KWU3 }}$ |  |  |  | 0: "0" detect <br> 1: "1" detect |  |  |  |  |
|  | IDLE2IN | Input level of $\overline{\mathrm{KWU}}$ |  |  |  | 0: "0" detect <br> 1: "1" detect |  |  |  |  |
|  | IDLE1IN | Input level of $\overline{\mathrm{KWU1}}$ |  |  |  | 0 : "0" detect <br> 1: "1" detect |  |  |  |  |
|  | IDLEOIN | Input level of $\overline{\text { KWUO }}$ |  |  |  | 0 : " 0 " detect <br> 1: "1" detect |  |  |  |  |

Figure 2.12.2 Key-on Wakeup Control Register

### 2.13 Pulse Width Modulation Circuit Output

The TMP88CS38B/CM38B/CP38B has four 12-bit resolution PWM output channels including two 14-bit resolution selectable and six 7-bit resolution PWM output channels.

DA converter output can easily be obtained by connecting an external low-pass filter. PWM outputs are multiplexed with general purpose I/O ports as; P40 ( $\overline{\mathrm{PWM} 0}$ ) to P47 ( $\overline{\mathrm{PWM} 7}$ ), P50 ( $\overline{\text { PWM } 8}$ ), P51 ( $\overline{\text { PWM9 }}$ ). PWM output is negative logic. When these ports are used PWM outputs, the corresponding bits of P4, P5 output latches and input/output control latches should be set to " 1 ".

In STOP mode, PWM output pin keeps high-level. When operation mode is changed from STOP mode to NORMAL mode, PWM control register (PWMCR1A, PWMCR2A, PWMCR1B, PWMCR2B) are initialized.

### 2.13.1 Configuration



Figure 2.13.1 PWM Output Circuit

### 2.13.2 PWM Output Wave Form

(1) $\overline{\text { PWM0 }}$ to $\overline{\text { PWM1 }}$ Outputs
$\overline{\text { PWM0 }}$ and $\overline{\text { PWM1 }}$ output can be selected 12-bit or 14-bit resolution PWM outputs.

1. 12-bit resolution PWM output

When these are used as 12 -bit PWM output, one period is $\mathrm{TM}=2^{13} / \mathrm{fc}[\mathrm{s}$ ] (When


The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of TS. The lower 8 bits of the PWM data latch is $\mathrm{n}(\mathrm{n}=1$ to 255 ), the low level pulse width with a cycle becomes $n \times t_{0}[\mathrm{~s}]\left(\mathrm{t}_{0}=2 / \mathrm{fc}[\mathrm{s}]\right.$ when $\mathrm{DV} 1 \mathrm{CK}=0, \mathrm{t}_{0}=4 / \mathrm{fc}$ [s] when DV1CK = 1).

The upper 4 bits of the PWM data latch controls a position to output the additional pulses. When the upper 4 bits of the PWM data latch is m, the additional pulses are generated in each of $m$ periods out of 16 periods contained in a $\mathrm{T}_{\mathrm{M}}$ period.

The relationship between the 4-bit data and the position of $\mathrm{T}_{\mathrm{S}}$ period where the additional pulses are generated is shown in Table 2.13.1.

Table 2.13.1 The Addition Pulse (12-bit mode)
a)

| Bit Position of the Lower 4 Bits of PWMDRxH |  |  |  | Relative position of $\mathrm{T}_{\mathrm{S}}$ in $\mathrm{T}_{\mathrm{M}}$ period where the additional |  |
| :---: | :---: | :---: | :---: | :--- | :---: |
| Bulse is generated. (Number of $\mathrm{T}_{\mathrm{S}}(\mathrm{I})$ is listed) |  |  |  |  |  |
| 0 | Bit10 | Bit9 | Bit8 | No additional pulse |  |
| 0 | 0 | 0 | 0 | 1 |  |
| 0 | 0 | 0 | 1 | 8 |  |
| 0 | 0 | 1 | 0 | 4,12 |  |
| 1 | 1 | 0 | 0 | $2,6,10,14$ |  |

Note 1: The bit positions of a) to e) can be combined.
Note 2: If the low order eight bits for the PWM data latch are set to "FFH", be sure to set the high order four bits for this latch to " OOH ".
2. 14-bit resolution PWM output

When these are used as 14 -bit PWM output, one period is $T_{M}=2^{15} / \mathrm{fc}[\mathrm{s}$ ] (When $\mathrm{DV} 1 \mathrm{CK}=0$ ) and $\mathrm{TM}=2^{16} / \mathrm{fc}[\mathrm{s}](\mathrm{When} \mathrm{DV} 1 \mathrm{CK}=1)$ and sub period is $\mathrm{T}_{\mathrm{S}}=\mathrm{TM}_{\mathrm{M}} / 64$.

The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of TS. The lower 8 bits of the PWM data latch is $\mathrm{n}(\mathrm{n}=1$ to 255 ), the low level pulse width with a cycle becomes $\mathrm{n} \times \mathrm{t}_{0}[\mathrm{~s}]\left(\mathrm{t}_{0}=2 / \mathrm{fc}[\mathrm{s}]\right.$ when $\mathrm{DV} 1 \mathrm{CK}=0$, $\mathrm{t}_{0}=4 / \mathrm{fc}$ [s] when DV1CK = 1).

The upper 6 bits of the PWM data latch controls a position to output the additional pulses. When the upper 6 bits of the PWM data latch is m, the additional pulses are generated in each of $m$ periods out of 64 periods contained in a TM period.

The relationship between the 6 -bit data and the position of TS period where the additional pulses are generated is shown in Table 2.13.2.

Table 2.13.2 The Addition Pulse (14-bit mode)
a)

| Bit Position of the Lower 6 Bits of PWMDRxH |  |  |  |  | Relative position of $T_{S}$ in $T_{M}$ period where the additional <br> pulse is generated. (Number of $T_{S}(1)$ is listed) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| Bit13 | Bit12 | Bit11 | Bit10 | Bit9 | Bit8 | No additional pulse |
| 0 | 0 | 0 | 0 | 0 | 0 | N |
| 0 | 0 | 0 | 0 | 0 | 1 | 32 |
| 0 | 0 | 0 | 0 | 1 | 0 | 16,48 |
| 0 | 0 | 0 | 1 | 0 | 0 | $8,24,40,56$ |
| 0 | 0 | 1 | 0 | 0 | 0 | $4,12,20,28,36,44,52,60$ |
| 0 | 1 | 0 | 0 | 0 | 0 | $2,6,10,14,18,22,26,30,34,38,42,46,50,54,58,62$ |
| 1 | 0 | 0 | 0 | 0 | 0 | $1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31,33$, <br> $35,37,39,41,43,45,47,49,51,53,55,57,59,61,63$ |

Note 1: The bit positions of a ) to g ) can be combined.
Note 2: If the low order eight bits for the PWM data latch are set to "FFH", be sure to set the high order 6 bits for this latch to " 00 H ".
(2) $\overline{\text { PWM2 }}$ to $\overline{\text { PWM3 }}$ Outputs
$\overline{\text { PWM2 }}$ and $\overline{\text { PWM3 }}$ output are 12-bit resolution PWM outputs.
One period is $\mathrm{T}_{\mathrm{M}}=2^{13} / \mathrm{fc}[\mathrm{s}](\mathrm{When} \mathrm{DV} 1 \mathrm{CK}=0)$ and $\mathrm{TM}=2^{14} / \mathrm{fc}[\mathrm{s}] \quad($ When $\mathrm{DV} 1 \mathrm{CK}=$ $1)$ and sub period is $\mathrm{Ts}=\mathrm{Tm} / 16$.

The lower 8 bits of the PWM data latch controls the low level pulse width with a cycle of TS. The lower 8 bits of the PWM data latch is $n(n=1$ to 255$)$, the low level pulse width with a cycle becomes $\mathrm{n} \times \mathrm{t}_{0}[\mathrm{~s}]\left(\mathrm{t}_{0}=2 / \mathrm{fc}[\mathrm{s}]\right.$ when $\mathrm{DV} 1 \mathrm{CK}=0, \mathrm{t}_{0}=4 / \mathrm{fc}[\mathrm{s}]$ when DV1CK = 1) .

The upper 4 bits of the PWM data latch controls a position to output the additional pulses. When the upper 4 bits of the PWM data latch is m , the additional pulses are generated in each of m periods out of 16 periods contained in a TM period.

The relationship between the 4 -bit data and the position of Ts period where the additional pulses are generated is shown in Table 2.13.1.
(3) $\overline{\text { PWM4 }}$ to $\overline{\text { PMW9 }}$ Outputs

These are 7 -bit resolution PWM outputs.
One period is $\mathrm{T}_{\mathrm{N}}=2^{8} / \mathrm{fc}[\mathrm{s}]($ When $\mathrm{DV} 1 \mathrm{CK}=0)$ and $\mathrm{T}_{\mathrm{N}}=2^{9 / \mathrm{fc}}[\mathrm{s}]($ When $\mathrm{DV} 1 \mathrm{CK}=1)$.
The 7 bits of the PWM data latch controls the low level pulse width with a cycle of $\mathrm{T}_{\mathrm{N}}$. The lower 7 bits of the PWM data latch is $\mathrm{k}(\mathrm{k}=1$ to 127$)$, the low level pulse width with a cycle becomes $\mathrm{k} \times \mathrm{t}_{0}[\mathrm{~s}]\left(\mathrm{t}_{0}=2 / \mathrm{fc}[\mathrm{s}]\right.$ when $\mathrm{DV} 1 \mathrm{CK}=0, \mathrm{t}_{0}=4 / \mathrm{fc}[\mathrm{s}]$ when DV1CK $=1$ ).

14-bit resolution PWM mode: The additional pulse Ts (1) and Ts (63)


12-bit resolution PWM mode: The additional pulse Ts (1) and Ts (15)


Note 1: If the pulse width is set to " 00 H ", PWM will note operate. Its output will remain high.
Note 2: If the pulse width is set to "FFH", settings for additional pulses cannot be made. Be sure to set the pulse width to " OOH ".

Figure 2.13.2 PWM Output Waveform

### 2.13.3 Control

PWM output is controlled by PWM control register (PWMCR1A, PWMCR1B, PWMCR2A, PWMCR2B) and PWM data buffer register (PWMDBR1, PWMDBR2).

| PWM Control Register 1A |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7 | 6 | 5 | 4 | 3 | 2 | 10 | (Initial value: *000 0000) |  |
| PWMCR1A (00028H) |  | - | ABORT1 | START3 | START2 | START1 | STARTO | $\begin{gathered} \text { RESOLUTION } \\ 1,0 \end{gathered}$ |  |  |
|  | ABORT1 |  |  | Abort PWM operation of channel 3 to 0 |  |  | 0: Operation <br> 1: PWM abort (PWM outputs are fixed to a high level.) |  |  | Write only |
|  | START3 |  |  | Start channel 3 |  |  | 0: Stop $\overline{\text { PWM3 }}$ <br> 1: Start PWM3 |  |  |  |
|  | START2 |  |  | Start channel 2 |  |  | 0: Stop PWM2 <br> 1: Start PWM2 |  |  |  |
|  |  |  | ART1 | Start channel 1 |  |  | $\begin{array}{ll} 0: & \text { St } \\ 1: & \text { St } \end{array}$ | $\begin{aligned} & \text { pp } \overline{\mathrm{PWM} 1} \\ & \text { art } \overline{\mathrm{PWM} 1} \end{aligned}$ |  |  |
|  |  |  | ART0 | Start channel 0 |  |  | $\begin{array}{ll} 0: & \mathrm{St} \\ 1: & \mathrm{St} \end{array}$ | $\begin{aligned} & \text { pp } \overline{\mathrm{PWMO}} \\ & \text { art } \overline{\mathrm{PWMO}} \end{aligned}$ |  |  |
|  |  | ESO | LUTION1 | Select channel 1 resolution |  |  | $\begin{array}{ll} 0: & 14 \\ 1: & 12 \\ \hline \end{array}$ | bit resolution -bit resolution |  |  |
|  |  | ESO | LUTION2 | Select channel 0 resolution |  |  | $\begin{array}{ll} 0: & 14 \\ 1: & 12 \end{array}$ | bit resolution -bit resolution |  |  |

Note 1: *: Don't care
Note 2 After set the ABORT1 to " 1 ", the ABORT1 is cleared to " 0 " automatically.
Note 3: PWMCR1A is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.

PWM Control Register 1B

|  | 76 | $5 \quad 4$ | 21 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PWMCR1B (00029H) |  |  | PWMCHS1 | PWMHL | (Initial value: **** *000) |  |
|  | PWMCHS1 | Select the PWM data latch of 12-bit PWM channel | 00: Channel 0 <br> 01: Channel 1 <br> 10: Channel 2 <br> 11: Channel 3 |  |  | Write only |
|  | PWMHL | Select upper or lower data transfer buffer (PWMDBR1) | 0: Lower 8 bits <br> 1: Upper 4 bits or 6 bits |  |  |  |

Note 1: *: Don't care
Note 2: PWMCR1B is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.

PWM Data Buffer Register 1


Write only (Initial value: 0000 0000)

Note 1: PWMDBR1 is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.
Note 2: When operation mode is changed from STOP mode to NORMAL mode, PWMCR1A, PWMCR1B are initialized.

Figure 2.13.3 PWM Control Register 1A/1B and PWM Data Buffer Register 1


Note 1: *: Don't care
Note 2 After set the ABORT2 to " 1 ", the ABORT2 is cleared to " 0 " automatically.
Note 3: PWMCR2A is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.

PWM Control Register 2B
PWMCR2B
(OOFF6H)

Note 1: *: Don't care
Note 2: PWMCR2B is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.

PWM Data Buffer Register 2

|  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PWMDBR2 (00FF7H) |  |  |  |  |  |  |  | Write only <br> (Initial value: *000 0000) |

Note 1: *: Don't care
Note 2: PWMDBR2 is write-only register and cannot be used with any of the read-modify-write instructions such as SET, CLR, etc.

Note 3: When operation mode is changed from STOP mode to NORMAL mode, PWMCR2A, PWMCR2B are initialized.

Figure 2.13.4 PWM Control Register 2A/2B and PWM Data Buffer Register 2


Note 1: *: Don't care
Note 2: The all bits except DV1CK are cleared to "0".
Figure 2.13.5 DIVIDER Control Register
(1) Internal counter

The internal counter of PWM outputs is a free running counter. The all bits of counter are set to " 1 " and are not counted up at one of the following conditions.

1. During reset
2. The operation mode is changed to STOP mode.
3. Setting ABORTx ( $\mathrm{x}: 1,2$ ) to " 1 ".
4. The START3 to 0 are " 0 " in 12 -bit PWM outputs. The START9 to 4 are " 0 " in 7 -bit PWM outputs.
5. The lower 8 -bit of PWM data latch in 12 -bit PWM outputs is " 00 H ". The PWM data latch in 7 -bit PWM outputs is " 00 H ".
(2) Outputs control and programming of PWM data

The PWM outputs are fixed to a high-level immediately when the ABORTx $(x: 1,2)$ is set to " 1 ". The PWM outputs starts the operation when the STARTx ( $\mathrm{x}: 0$ to 9 ) is set to " 1 ".

The data from the transfer buffer to a PWM data latch is transferred when the all bits of internal counter are set to " 1 ". Therefore, the data is transferred to a PWM data latch immediately when the internal counter is initialized. And the data is transferred to a PWM data latch at the beginning of the next cycle when all bits of the internal counter are not set to " 1 ".

The sequence of writing the output data to PWM data latches is shown as follows;

1. $\overline{\text { PWM0 }}$ to $\overline{\text { PWM1 }}$
a) Write the channel number of PWM data latch to PWMCHS1 (Bit2 and 1 in PWMCR1B) and clear PWMHL (Bit0 in PWMCR1B) to " 0 ".
b) Write the lower 8 -bit PWM output data to PWMDBR1.
c) Write the channel number of PWM data latch to PWMCHS1 and set PWMHL to " 1 ".
d) Write the upper 4-bit or 6-bit PWM output data to PWMDBR1.
e) Select the resolution of PWM output to RESOLUTIONx (x: 0, 1) (Bit0 and 1 in PWMCR1A) and set STARTx ( $\mathrm{x}: 0,1$ ) (Bit2 and 3 in PWMCR1B) to " 1 ".

Note: PWM output data must be write to PWMDBR1 in the order of the lower 8-bit PWM output data, the upper 4-bit (or 6-bit) PWM output data. If the upper 4-bit (or 6-bit) PWM output data is write to PWMDBR1, the lower 8-bit PWM output data is not changed (except when lower 8-bit PWM output data is " 00 H ").
2. $\overline{\mathrm{PWM} 2}$ to $\overline{\mathrm{PWM} 3}$
a) Write the channel number of PWM data latch to PWMCHS1 and clear PWMHL to " 0 ".
b) Write the lower 8-bit PWM output data to PWMDBR1.
c) Write the channel number of PWM data latch to PWMCHS1 and set PWMHL to " 1 ".
d) Write the upper 4-bit PWM output data to PWMDBR1.
e) Set STARTx $(x: 2,3)$ to " 1 ".


Figure 2.13.6 Waveform of $\overline{\mathrm{PWMO}}$ to $\overline{\mathrm{PWM}}$
Note: PWM output data must be write to PWMDBR1 in the order of the lower 8-bit PWM output data, the upper 4-bit (or 6-bit) PWM output data. If the upper 4-bit (or 6-bit) PWM output data is write to PWMDBR1, the lower 8-bit PWM output data is not changed (except when lower 8-bit PWM output data is " 00 H ").
3. $\overline{\mathrm{PWM} 4}$ to $\overline{\mathrm{PWM} 9}$
a) Write the channel number of PWM data latch to PWMCHS2.
b) Write the lower 7-bit PWM output data to PWMDBR2.
c) Set STARTx (x: 4 to 9 ) to " 1 ".


Figure 2.13.7 Waveform of $\overline{\mathrm{PWM} 4}$ to $\overline{\mathrm{PWM} 9}$

Example: at $\mathrm{fc}=16 \mathrm{MHz}, \mathrm{DV} 1 \mathrm{CK}=0$
$\overline{\text { PWMO }}$ pin outputs a 14-bit resolution PWM wave form with a low level of $32 \mu \mathrm{~s}$ width and no additional pulse. $\overline{\text { PWM1 }}$ pin outputs a 12-bit resolution PWM wave form with a low level of $16 \mu \mathrm{~s}$ width and no additional pulse. $\overline{\text { PWM4 }}$ pin outputs a PWM wave form with a low level of $8 \mu$ s width.

| LD | (CGCR), 00H | DV1CK $=0$ |
| :---: | :---: | :---: |
| LD | (PWMCR1B), 00H | Select the lower 8 bits of $\overline{\text { PWMO }}$ output data latch |
| LD | (PWMDBR1), 80H | $32 \mu \mathrm{~s} \div 4 / \mathrm{fc}=80 \mathrm{H}$ |
| LD | (PWMCR1B), 01H | Select the upper 6 bits of $\overline{\text { PWM0 }}$ output data latch |
| LD | (PWMDBR1), 00H | No additional pulse $=00 \mathrm{H}$ |
| LD | (PWMCR1B), 02H | Select the lower 8 bits of $\overline{\text { PWMO }}$ output data latch |
| LD | (PWMDBR1), 40H | $16 \mu \mathrm{~s} \div 4 / \mathrm{fc}=40 \mathrm{H}$ |
| LD | (PWMCR1B), 03H | Select the upper 4 bits of $\overline{\text { PWMO }}$ output data latch |
| LD | (PWMDBR1), 01H | Additional pulse ( $\mathrm{Ts}_{(8)}$ ) $=01 \mathrm{H}$ |
| LD | (PWMCR1A), 0DH | Start $\overline{\text { PWM0 }}$ and $\overline{\text { PWM1 }}$, $\overline{\text { PWM0 : 14-bit resolution, } \overline{\text { PWM1 }} \text { : 12-bit resolution }}$ |
| LD | (PWMCR2B), 00H | Select $\overline{\text { PWM4 }}$ output data latch |
| LD | (PWMDBR2), 20H | $8 \mu \mathrm{~s} \div 2 / \mathrm{fc}=20 \mathrm{H}$ |
| LD | (PWMCR2A), 01H | Start PWM4 |

### 2.14 Test Video Signal Output for Adjusting TV Screen

The TMP88CS38B/CM38B/CP38B has a built-in video signal output circuit to output necessary signal for TV screen adjustment.

| Picture pattern | $:$ | Total eight types, monochromatic inversion possible |  |
| :--- | :--- | :--- | :--- |
| Output format | $:$ | Three states (H, L, High-Z) output |  |
|  |  | Comp.sync duration time | L output |
|  | Black level/pedestal duration time  <br> White level duration time High-Z output <br>   | H output |  |

### 2.14.1 Configuration



Figure 2.14.1 Test Video Signal Output Circuit

### 2.14.2 Control

The test video signal output circuit can be controlled with the test video signal control register.

| $\begin{aligned} & \text { TVSCR } \\ & \text { (00FE6H) } \end{aligned}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SGEN | SGVBLK | SGPAL | SGIV | SGCHS | "0" | : SGPAT | "0" | (Initial value: 00000 |  |
|  | SGEN | SG f | unction s | ection |  |  | Disable Enable |  |  |  |
|  | SGVBLK | K Picu <br> time | ure signa | for VB | K duration |  | Output No output |  |  |  |
|  | SGPAL | PAL/ | NTSC se | ction |  |  | NTSC PAL |  |  |  |
|  | SGIV | Patte | rn mono | romatic | inversion |  | No inversi Inversion |  |  |  |
|  | SGCHS | OSD | synchro | us sign | selection |  | Port Pseudo s |  |  | Write only |
|  | SGPAT | Disp | lay patter |  |  | $\begin{aligned} & \hline 00 \\ & 00 \\ & 01 \\ & 01 \\ & 10 \\ & 10 \\ & 11 \\ & 11 \end{aligned}$ | :Black on th :White on th :Cross hatch :Cross dot : Cross bar :White on th H signal p :H resolutio | who <br> who <br> tern <br> upp <br> rn <br> patt | lack on the lower side |  |
|  | Note 1: Test video signal output function does work correctly when fc is not 16 MHz . <br> Note 2: Clear the bit2 and bit0 of TVSCR to " 0 ". |  |  |  |  |  |  |  |  |  |

Figure 2.14.2 Test Video Signal Control Register

### 2.14.3 Functions

Video signal output is to generate monochromatic picture signal output to take easily the necessary tests such as TV screen white adjustment and screen distortion amplitude adjustment implemented on the final manufacturing process of a TV receiver set.

Table 2.14.1 Display Pattern and TV Screen


There are three states of the output to generate picture signal with the external circuit of the resistance divided voltage.

Example of picture output generation)


### 2.15 On-screen Display (OSD) Circuit

The TMP88CS38B/CM38B/CP38B features a built-in on-screen display circuit used to display characters and symbols on the TV screen. There are 384 characters and any characters can be displayed in an area of 32 columns $\times 12$ lines (Include 2 columns for solid space). With an OSD interrupt, additional lines can be displayed. The functions of the OSD circuit meet the requirements of on-screen display functions of closed caption decoders based on FCC standards.

OSD circuit functions are as follows:
(1) Number of character fonts: 384
(2) Number of display characters: 384 ( 32 columns $\times 12$ lines)
(3) Composition of character: Horizontal $16 \times$ vertical 18 dots
(4) Character sizes: 3 kinds for large, middle and small characters
(Selectable line by line)
(5) Character ornamentation function

Fringing function
Smoothing function
Slant function (Italics)
Blinking function
Underline
(6) Solid space
(7) Area plane function: 2 planes
(8) Full-raster blanking function
(9) Display colors Character colors: 8 or 15 colors (Selectable character by character)

Fringe color: 8 or 15 colors (Selectable page by page)
Background color: 8 or 15 colors (Selectable page by page)
Area plane color: 8 or 15 colors (Selectable each of 2 planes)
Raster color: 8 or 15 colors (Selectable page by page)
(10) Display position: 256 horizontal steps and 512 vertical steps for code plane
: 512 horizontal steps and 512 vertical steps for area plane
(11) Window function: 512 vertical steps
(12) Half transparency output function

The TMP88CS38B/CM38B/CP38B outputs OSD through 3 planes; code, area, and raster. 3 planes function independently. In addition, they are displayed simultaneously. There is the priority among these 3 planes, so they are displayed on a screen according to the priority.

These 3 planes have the priority such as
Code $>$ Area > Raster.

1. Code plane

OSD character is displayed on the code plane.
The code plane consists of 32 characters $\times 1$ row and a total of 12 planes. The 12 planes have the priority such as code $1>$ code $2>\ldots>$ code $11>$ code 12 .

On the code plane, characters of $16 \times 18$ dots is displayed. These fonts are called characters, and read from character ROM and display memory through the character code on the display memory.
2. Area plane

The area on a screen is displayed on the area plane.
The area plane can display 2 square areas of any size by specifying coordinates. The 2 planes have the priority such as area plane $1>$ area plane 2.

### 2.15.1 Configuration



Figure 2.15.1 OSD Circuit

### 2.15.2 Character ROM and Display Memory

(1) Character ROM

The character ROM contains 384 character fonts. The user can set fonts as desired. The character ROM consists of 384 characters in $16 \times 18$ dots (Character codes 000 H to $17 \mathrm{FH})$. Each dot corresponds to one bit in the character ROM. When a bit in the character ROM is set to " 1 ", the corresponding dot is displayed; if set to " 0 ", the dot is not displayed. The start address in the character ROM corresponding to a character code is determined by the following expression:

Start address in character ROM $=\mathrm{CRA} \times 40 \mathrm{H}+20000 \mathrm{H}$
Since character code 000 H is used as blank character, the character font for this character code cannot be changed. Write " 0 " in the data of character code 000 H .

Write the data "FFH" to all unused address (5th bit of an address is " 1 " and also the lower 4 bits of an address are 2 H to FH ) in character ROM.

Figure 2.15.2 (a) shows an example of the character font configuration for the character code 000 H and $001_{\mathrm{H}}$, together with the ROM addresses and data.

Figure 2.15 .2 (b) shows the character ROM dump list for these 2 character fonts.

Note 1: CRA: Character code ( 000 H to 17 FH ).
Note 2: A data can not be read from character ROM by software.
Note 3: When ordering a mask, load the data to character ROM at addresses 20000H to 25FFFH.
And the data in unused are of character ROM are must be specified to FFH.

(a) Character font configuration

| 20000/ | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 20010/ | 00 | 00 | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF |
| 20020/ | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 |
| 20030/ | 00 | 00 | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF |
| 20040/ | 3 F | 7F | E0 | CO | 00 | 00 | 00 | 01 | 03 | 07 | OE | 1 C | 38 | 70 | FF | FF |
| 20050/ | 00 | 00 | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF |
| 20060/ | C0 | E0 | 70 | 30 | 30 | 70 | E0 | C0 | 80 | 00 | 00 | 00 | 00 | 00 | F0 | F0 |
| 20070/ | 00 | 00 | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF | FF |  |

(b) ROM dump list

Note: $\quad$ Shared portions indicate unused data.

Figure 2.15.2 Character Font Configuration and ROM Dump List
(2) Display memory

Each character of the 384 characters displayed in 32 columns $\times 12$ lines consists of 16 bits in the display memory. Five data items are written to the display memory: Character code, color data, blinking specification, underline enable, and slant enable.

There are two modes for writing display data to the display memory. One mode is used for writing all display data (Character code, color data, blinking specification, underline enable, and slant enable) simultaneously. The other mode is used for changing either character codes or the remaining data items (Color data, blinking specification, underline enable, and slant enable). How to write display data to the display memory is described in section 2.15.5.7 (1).

Note: The display memory is in an unknown state at reset.
Display memory configuration

- Character code specification register (9 bits) .... CRA8 to CRA0
- Color data specification register (4 bits)............IDT/RDT/GDT/BDT
- Blinking specification register (1 bit) ................ BLF
- Underline enable register (1 bit).........................EUL
- Slant enable register (1 bit).................................SLNT


Figure 2.15.3 Display Memory Bit Configuration


Figure 2.15.4 Display Memory Address Configuration

### 2.15.3 OSD Circuit Control

The OSD circuit performs control functions using the OSD control registers which reside in addresses 0001 DH to 0001 FH and 00024 H to 00025 H in the special function registers (SFR), and in addresses 0 F 80 H to 0 FBFH in the data buffer register (DBR). Section 2.15.5.9 shows the OSD control registers. The OSD control registers are used to set display start position, display character designs (that is, fringing, smoothing, color data, character size, and etc.), display memory addresses, and character codes.

Setting the display on-off control bit, DON, (Bit0 in ORDON) to " 1 " enables display (Starts display). Setting DON to " 0 " disables display (Halts display).

Note: The contents of OSD control registers except PIDS, P67S to P64S are initialized in STOP mode.

### 2.15.4 OSD Control Register Write

There are lists of the OSD control registers on Table 2.15.5.10 and Table 2.15.5.11.
When data is written into a shaded register, the data is transferred to the OSD circuit, and then the data becomes valid. After data is written into an unshaded register, the data is transferred to the OSD circuit, and then the data becomes valid.

To transfer the contents of a control register to the OSD circuit, use data transfer request register RGWR (Bit2 in ORDON).

Setting " 1 " in the RGWR register outputs the transfer request signal to the OSD circuit. Three instruction cycles later, transfer of the written data to the OSD circuit starts. While the data is being transferred, data transfer status monitoring flag RGWR (Bit2 in ORDON) is " 1 ". When this transfer is completed, the flag is cleared to " 0 ".

```
Written data transfer register (1 bit) ....RGWR (Bit2 in ORDON)
    "0" ....... Initialized state
    "1" ....... Transfers written data to OSD circuit.
    (After transfer, RGWR is reset to 0.)
```

Note: Don't write "0" to RGWR.
(1) RGWR system


Figure 2.15.5 RGWR System
(2) Transfer timing

1. No display area

When having set RGWR to " 1 " during no display area, the timing OSD register can be transferred is at the falling edge of $\overline{\mathrm{HD}}$ signal.


Figure 2.15.6 Data Transfer Timing in No Display Area
2. Display area (including any lines specified as display off by character size)

When having set RGWR to " 1 " during display area, the timing OSD register can be transferred is at the falling edge of $\overline{\mathrm{HD}}$ signal when the display line has been finished.


Figure 2.15.7 Data Transfer Timing in Display Area

### 2.15.5 OSD Function

### 2.15.5.1 Signal Control (Port I/O)

(1) P6 port output select function

This function is used to select whether the contents of port P57, P67 to P64 will be output or I, R, G, B, Y/BL signals of the OSD circuit will be output on pins P57, P67 to P64.

P57 port output select registers (1 bit): PIDS (Bit3 in ORP6S)

|  | PIDS $=0$ | PIDS $=1$ |
| :---: | :---: | :---: |
| P57 | I | Port |

P67 to P64 port output select registers (4 bits): P67S, P66S, P65S, P64S, (Bit7 to 4 in ORP6S)

|  | $\mathrm{P} 6 \mathrm{nS}=0$ | $\mathrm{P} 6 \mathrm{nS}=1$ |
| :---: | :---: | :---: |
| P 64 | R |  |
| P 65 | G |  |
| P66 | B |  |
| P 67 | $\mathrm{Y} / \mathrm{BL}$ |  |

(2) OSD pin output polarity control function

This function is used to select the polarity of the OSD outputs for RGB, I and Y/BL.

Output polarity control register (4 bits) $\qquad$ BLIV, YIV, RGBIV, IIV (Bit3 to 0 in ORIV)

$$
\begin{array}{lll}
" 0 " & \ldots . . . & \text { Active high } \\
" 1 " & \ldots . . . & \text { Active low }
\end{array}
$$

(3) OSD pin input polarity control

Input polarity control
Input polarity control register of RIN/GIN/BIN/Y/BLIN (2 bits)
For Y/BLIN $\qquad$ YBLII (Bit5 in ORIV)
For RIN, GIN, and BIN ...... RGBII (Bit4 in ORIV)
Input polarity control
YBLII,
RGBII
"0" ...... Active high
"1" ...... Active low

Input polarity control register of $\overline{\mathrm{HD}} / \overline{\mathrm{VD}}$ (2 bits)
For $\overline{\mathrm{VD}}$ $\qquad$ VDPOL (Bit7 in ORIV)

For $\overline{\mathrm{HD}}$ $\qquad$ .HDPOL (Bit6 in ORIV)
Input polarity control
VDPOL, HDPOL
" 0 " ....... Not invert input signal
"1" ....... Invert input signal


Figure 2.15.8 $\overline{\mathrm{VD}} / \overline{\mathrm{HD}}$ input and VDPOL/HDPOL
(4) $Y / B L$ signal select function

This function is used to select either Y or BL signal output from the $\mathrm{Y} / \mathrm{BL}$ pin.
Y/BL signal select register ( 1 bit).........YBLCS (Bit7 in ORP6S)
$\begin{array}{lll}\text { " } 0 " & \text {....... } & \text { Y signal output } \\ " 1 " & \text {..... } & \text { BL signal output }\end{array}$
Y signal..............Output in all OSD areas (Logical OR for R, G, B data as character data, fringing data, area data, etc.)
BL signal ........... When EXBL is " 0 ":
Output in all display character areas (except for character code 000 H : Blank character) When EXBL is " 1 ":
Output in the whole page
(5) I signal function select

When PISEL (Bit6 in ORETC) is set to " 1 " and PIDS (Bit3 in ORP6S) is set to " 0 ", Port 57 ( ( pin) can be used as half transparency/half tone through an extra circuit.

At half transparency/half tone function, contents of IDT (Bit3 in ORDSN) is make no sense. Therefore character color are limited to 8 colors.

Similarly background color, fringing color, raster plane color and area plane color are limited to 8 colors.

When PISEL (Bit6 in ORETC) sets to " 0 " and, PIDS (Bit3 in ORP6S) set to " 0 ", 15 colors to be selectable.
(6) $\mathrm{R}, \mathrm{G}, \mathrm{B}, \mathrm{Y} / \mathrm{BL}$ Internal/external signal select.

Selects either R, G, B, and Y/BL signals from the internal OSD circuit, or RIN, GIN, BIN, and Y/BLIN signals from external input.

R, G, B, Y/BL signal select registers (2 bits)........ MPXS1/MPXS0
(Bits 1 and 0 in ORP6S)
$\begin{array}{lll}\text { " } 00 " & \ldots . . . . & \begin{array}{l}\text { Simultaneous output (Signal from the OSD circuit } \\ \text { has higher priority.) }\end{array} \\ \text { " } 01 " & \ldots . . . . & \text { Output of signal from internal OSD circuit } \\ \text { " } 10 " & \ldots . . . & \text { Output of signal from external input } \\ \text { " } 11 " & \ldots . . . & \begin{array}{l}\text { Simultaneous output (External input signal has } \\ \text { higher priority.) }\end{array}\end{array}$

### 2.15.5.2 OSD Data Output Format Control

(1) Scan mode

The double scan mode is used to handle non-interlaced scanning TV. When double scan mode is enabled, the vertical display counter increases every 2 scan lines and a vertical size of a dot is double. This function is enabled by setting VDSMD (Bit7 in ORETC) in the OSD control register to " 1 ".

Scan mode select register (1 bit).......VDSMD (Bit7 in ORETC)

$$
\begin{array}{lll}
" 0 " & . . . . . . & \text { Normal mode } \\
" 1 " & \ldots . . . & \text { Double scan mode }
\end{array}
$$

Note 1: The data written to those control register is transferred to the OSD circuit and become valid when the data is written.

Note 2: When OSD circuit is used on an interlace scanning TV, a jitter elimination circuit must be enabled and set AFLD to " 1 " in JECR.

Table 2.15.5.1 The Difference of 2 Types of Scan Mode

|  | Normal Mode | Double Scan Mode |
| :---: | :---: | :---: |
| Specification unit of vertical display <br> start position | One scanning line | Two scanning lines |
| 1 dot height | - | Normal mode height $\times 2$ |



Figure 2.15.9 Scan Mode
2.15.5.3 Display Position Control
(1) Code display position setting

1. Horizontal display start position

The horizontal display start position can be set in 256 steps by writing to OSD control registers HS17 to HS10 (Bit7 to 0 in ORHS1). The value is in common with all lines.

Specification unit: 2 TOSC
Specification steps: 256
Specification horizontal display start position: Line 1 to 12: HS17 to HS10 (ORHS1)

$$
\mathrm{HS} 1=(\mathrm{HS} 17 \text { to HS10) } \mathrm{H} \times 2 \mathrm{TOSC}+20 \mathrm{TOSC}(\text { Line1 to } 12)
$$

## Note 1: TOSC: One cycle of OSD oscillation.

Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to " 1 ".
2. Vertical display start position

The vertical display start position can be specified for each display line using 512 steps by writing to VSn8 to VSn0 (in ORVSn (n: 1 to 12)).

Specification unit: 1 scan line
Specification steps: 512
Specification vertical display start position:
Line1: VS18 to VS10 (ORVS 1)
Line2: VS28 to VS20 (ORVS 2)
$\vdots$
Line12: VS128 to VS120 (ORVS 12)
Line $\mathrm{n}: \mathrm{VSn}=(\mathrm{VSn} 8$ to VSn 0$) \mathrm{H} \times 1 \mathrm{~T}_{\mathrm{HD}}(\mathrm{n}: 1$ to 12$)$
Note 1: THD: One cycle of $\overline{\mathrm{HD}}$ signal.
Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to " 1 ".

Note 3: If display lines are overlapped each other, previous display line is enabled and next line is disabled. If vertical display start positions of two or more lines are set on same value, high priority line is enabled. Lines of OSD (VS1 to VS12) are fixed priority levels as follows:
VS1 > VS2 > VS3 > ...... > VS12

Set the vertical display start position not to overlap display lines.


Note 4: The line which is displayed off is managed as a small size character line.
Note 5: Transfer the contents of vertical display start position registers into OSD circuit before the position of the scanning line coincides with their own vertical display start position.
(2) Area display position setting

The planes have the priority such as Code plane $>$ Area plane $1>$ Area plane $2>$ Raster plane.

1. Horizontal display start and end position

The horizontal display start position can be set in 512 steps by writing to OSD control registers AHSn8 to AHSn0 (Bit8 to 0 in ORAHSn). And also display stop position is correspond to AHEn8 to AHEn0 (Bit8 to 0 in ORAHEn). (n: 1 to 2)

Horizontal display start position
$\mathrm{AHSn}=(\mathrm{AHSn} 8 \text { to } \mathrm{AHSn} 0)_{\mathrm{H}} \times 2 \mathrm{TOSC}_{\mathrm{OS}}$
Horizontal display end position
AHEn $=(\text { AHEn } 8 \text { to AHEn } 0)_{H} \times 2$ TOSC
Note 1: Tosc: One cycle of OSD oscillation.
Note 2: If the horizontal display start position for characters is the same as that for areas, the two positions are not displayed at the same time. The horizontal display start position for characters is displayed 16 TOSC (Corresponding to a register value of 8) later than that for areas.
2. Vertical display start and end position

The vertical display start position can be set in 512 steps by writing to OSD control registers AVSn8to AVSn0 (Bit8 to 0 ORAVSn). And also display stop position is correspond to AVEn8 to AVEn0 (Bit8 to 0 in ORAVEn). (n: 1 to 2)

Vertical display start position

$$
\mathrm{AVSn}=(\mathrm{AVSn} 8 \text { to } \operatorname{AVSn} 0) \mathrm{H} \times \mathrm{T}_{\mathrm{HD}}
$$

Vertical display end position

$$
\text { AVEn }=(\operatorname{AVEn} 8 \text { to AVEn } 0)_{\mathrm{H}} \times \mathrm{T}_{\mathrm{HD}}
$$

Note: $\mathrm{T}_{\mathrm{HD}}$ : One cycle of $\overline{\mathrm{HD}}$ signal.


Figure 2.15.10 TV Scan Image
2.15.5.4 Character Ornamentation Control
(1) Character sizes

Character size can be selected line by line from 3 sizes. And display on/off also can be set line by line. Small, middle and large character size and display on/off can be set with OSD control registers CSn (n: 1 to 12, ORCS4, ORCS8, ORCS12) in the OSD control registers.

Character sizes: 3 sizes (Small, middle and large)
Character size and display on/off specification unit: Line
Character size select/display on/off register (2 bits $\times 12$ )
Line 1: CS1
Line 2: CS2
: :
Line 12: CS12

Table 2.15.5.2 Character Size and Display On/Off Specifications (n: 1 to 12)

| CSn (Upper bit) | CSn (Lower bit) | Character Size | Display On/Off |
| :---: | :---: | :---: | :---: |
| 1 | 1 | Small | On |
| 1 | 0 | Middle | On |
| 0 | 1 | Large | On |
| 0 | 0 | - | Off |

Note 1: The display off line operates like the width of small character size line thought the character is not displayed.

Note 2: The data written to these control registers is transmitted to OSD circuit by setting RGWR (Bit2 in ORDON) to " 1 ".

Note 3: When OSD circuit is used on an interlace scanning TV, a jitter elimination circuit must be enabled and set AFLD to " 1 " in JECR.

Note 4: When VDSMD and AFLD are " 0 ", only character of even display dot is displayed. (Refer to 2.16 a jitter elimination circuit.)

Table 2.15.5.3 Dot and Character Sizes

|  |  | VDSMD $=0$ (Normal mode) |  |  | VDSMD = 1 (Double scan mode) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Dot Size | Character Size |  | Dot Size | Character Size |  |
|  |  | $\begin{aligned} & \hline \text { EFRn = 0 } \\ & \text { (Fringe off) } \\ & \hline \end{aligned}$ | $\begin{gathered} \text { EFRn = } 1 \\ \text { (Fringe on) } \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { EFRn = 0 } \\ \text { (Fringe off) } \\ \hline \end{gathered}$ |  | $\begin{gathered} \hline \text { EFRn = } 1 \\ \text { (Fringe on) } \\ \hline \end{gathered}$ |
| EULAn $=0$ <br> (Underline off) | Small |  | $1 \mathrm{~T}_{\mathrm{OSC}} \times 0.5 \mathrm{~T}_{\mathrm{HD}}$ | $16 \mathrm{~T}_{\text {OSC }} \times 9^{\text {a }}$ HD | $16 \mathrm{~T}_{\text {OSC }} \times 11 \mathrm{~T}_{\mathrm{HD}}$ | $1 \mathrm{~T}_{\text {OSC }} \times 1 \mathrm{~T}_{\text {HD }}$ | $16 \mathrm{~T}_{\text {OSC }} \times 18 \mathrm{~T}_{\mathrm{HD}}$ | $16 \mathrm{~T}_{\mathrm{OSC}} \times 20 \mathrm{~T}_{\mathrm{HD}}$ |
|  | Middle | $2 \mathrm{TOSC} \times 1 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{~T}_{\mathrm{OSC}} \times 18 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{~T}_{\text {OSC }} \times 20 \mathrm{~T}_{\mathrm{HD}}$ | $2 \mathrm{~T}_{\text {OSC }} \times 2 \mathrm{~T}_{\text {HD }}$ | 32 T OSC $\times 36 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{~T}_{\mathrm{OSC}} \times 40 \mathrm{~T}_{\mathrm{HD}}$ |
|  | Large | $4 \mathrm{~T}_{\mathrm{OSC}} \times 2 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T}_{\mathrm{OSC}} \times 36 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T}_{\mathrm{OSC}} \times 40 \mathrm{~T}_{\mathrm{HD}}$ | $4 \mathrm{~T}_{\mathrm{OSC}} \times 4 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T}_{\text {OSC }} \times 72 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T}_{\mathrm{OSC}} \times 80 \mathrm{~T}_{\mathrm{HD}}$ |
| EULAn = 1 <br> (Underline on) | Small | $1 \mathrm{~T}_{\text {OSC }} \times 0.5 \mathrm{~T}_{\mathrm{HD}}$ | $16 \mathrm{~T}_{\mathrm{OSC}} \times 12 \mathrm{~T}_{\mathrm{HD}}$ | $16 \mathrm{~T}_{\text {OSC }} \times 13 \mathrm{~T}_{\mathrm{HD}}$ | $1 \mathrm{~T}_{\text {OSC }} \times 1 \mathrm{~T}_{\text {HD }}$ | $16 \mathrm{~T}_{\text {OSC }} \times 24 \mathrm{~T}_{\mathrm{HD}}$ | $16 \mathrm{~T}_{\mathrm{OSC}} \times 25 \mathrm{~T}_{\mathrm{HD}}$ |
|  | Middle | $2 \mathrm{TOSC} \times 1 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{~T}_{\text {OSC }} \times 24 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{~T}_{\text {OSC }} \times 25 \mathrm{~T}_{\mathrm{HD}}$ | $2 \mathrm{~T}_{\text {OSC }} \times 2 \mathrm{~T}_{\text {HD }}$ | $32 \mathrm{~T}_{\text {OSC }} \times 48 \mathrm{~T}_{\mathrm{HD}}$ | $32 \mathrm{Tosc} \times 50 \mathrm{~T}_{\mathrm{HD}}$ |
|  | Large | $4 \mathrm{~T}_{\mathrm{OSC}} \times 2 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T} \mathrm{OSC} \times 48 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{TOSC} \times 50 \mathrm{~T}_{\mathrm{HD}}$ | $4 \mathrm{~T}_{\mathrm{OSC}} \times 4 \mathrm{~T}_{\mathrm{HD}}$ | $64 \mathrm{~T}_{\text {OSC } \times 96 \mathrm{~T}_{\mathrm{HD}} \text { }}^{\text {d }}$ | $64 \mathrm{~T}_{\mathrm{OSC}} \times 100 \mathrm{~T}_{\mathrm{HD}}$ |

TOSC: One cycle of OSD oscillation, $\mathrm{T}_{\mathrm{HD}}$ : One cycle of $\overline{\mathrm{HD}}$ signal


Figure 2.15.11 Character Size
(2) Smoothing function

The smoothing function is used to make characters look smooth. Enabling smoothing displays $1 / 4$ dot between two dots connecting corner to corner within a character. Small size character can not be enabled smoothing. Smoothing is enabled by setting ESMZ (Bit4 in ORETC) in the OSD control register to " 1 ".

Smoothing specification unit:Display page
Smoothing specification register (1 bit)......ESMZ (Bit4 in ORETC)

$$
\begin{array}{lll}
" 0 " & \ldots . . . . & \text { Disable smoothing } \\
" 1 " & \ldots . . . & \text { Enable smoothing }
\end{array}
$$

Note: Data of the register is transferred to the OSD circuit and become valid when the data is written.


Figure 2.15.12 Available Form and Invalid Form for Smoothing


Figure 2.15.13 Smoothing Example
(3) Fringing function

The fringing function is used to display a character with a fringe width is 1 dot in a different color from that of the character. When a character is displayed with the maximum of 18 vertical dots and 16 horizontal dots, the fringe exceeds right and left, top, and bottom of the character display area. If there is an adjacent character that outer dot is active, then this dot will overrule the fringe in the horizontal direction. Underlines are not fringed.

Fringing is enabled for each line by setting EFR1 to EFR8 (OREFR8) and EFR9 to EFR12 (OREFR12) in the OSD control register to " 1 ".

A color for fringe is specified common to all lines using OSD control registers, IFDT, RFDT, GFDT, and BFDT (Bit3 to 0 in ORBK).

Fringing specification unit: Line
Fringing enable register ( 1 bit $\times 12$ ) .... EFRn (n: 1 to 8) (OREFR8), EFRn (n: 9 to 12) (OREFR12)
"0" ....... Disable fringing
"1" ....... Enable fringing

Fringe colors: 8 or 15
Fringe color specification unit: Display page
Fringe color register ( 4 bits).....IFDT, RFDT, GFDT, BFDT (Bit3 to 0 in ORBK)
I signal function select: PISEL (Bit6 in ORETC)
" 0 " ....... 15 colors specification
I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit.
" 1 " ....... 8 colors specification
Contents of IDT register is disregarded.
I pin can be used as half transparency/half tone through an extra circuit.

Note: The fringe of 1st column character does not exceed left, and the fringe of 32th character does not exceed right.

Table 2.15.5.4 Fringe Color (15 colors)

| IFDT | RFDT | GFDT | BFDT | Figure Color |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Blue |
|  | 0 | 1 | 0 | Green |
|  | 0 | 1 | 1 | Cyan |
|  | 1 | 0 | 0 | Red |
|  | 1 | 0 | 1 | Magenta |
|  | 1 | 1 | 0 | Yellow |
|  | 1 | 1 | 1 | White |
| 1 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Dark blue |
|  | 0 | 1 | 0 | Dark green |
|  | 0 | 1 | 1 | Dark cyan |
|  | 1 | 0 | 0 | Dark red |
|  | 1 | 0 | 1 | Dark magenta |
|  | 1 | 1 | 0 | Dark yellow |
|  | 1 | 1 | 1 | Gray |

## R, G, B pin output

Figure 2.15.14 Example Circuit for 15 Colors by I Pin.


Figure 2.15.15 (a) Fringing Example


Figure 2.15.16 (b) Fringing Example


Figure 2.15.17 (c) Fringing Example


Figure 2.15 .18 (d) Fringing Example
(4) Background function

Background color function is used to color the entire background for the character area (Refer to Table 2.15.4). Except the character area whose character code is 000 H .

This function is specified for each display page by setting EBKGD (Bit7 in ORRCL) in the OSD control register to " 1 ".

A background color is specified for each display page by setting IBDT, RBDT, GBDT, and BBDT (Bit7 to 4 in ORBK) in the OSD control registers.

Background specification unit: Display page
Background enable register (1 bit) ...... EBKGD (Bit7 in ORRCL)
" 0 " ....... Disable background
"1" ....... Enable background

Background color specification unit: Display page
Background color specification registers (4 bits) .... IBDT, RBDT, GBDT, BBDT (Bit7 to 4 in ORBK)

I signal function select: PISEL (Bit6 in ORETC)
" 0 " ....... 15 colors specification
I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit.
"1" ....... 8 colors specification
Contents of IBDT register is disregarded.
I pin can be used as half transparency/half tone through an extra circuit.

Table 2.15.5.5 Background Color ( 15 colors)

| IBDT | RBDT | GBDT | BBDT | Background Color |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Blue |
|  | 0 | 1 | 0 | Green |
|  | 0 | 1 | 1 | Cyan |
|  | 1 | 0 | 0 | Red |
|  | 1 | 0 | 1 | Magenta |
|  | 1 | 1 | 0 | Yellow |
|  | 1 | 1 | 1 | White |
| 1 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Dark blue |
|  | 0 | 1 | 0 | Dark green |
|  | 0 | 1 | 1 | Dark cyan |
|  | 1 | 0 | 0 | Dark red |
|  | 1 | 0 | 1 | Dark magenta |
|  | 1 | 1 | 0 | Dark yellow |
|  | 1 | 1 | 1 | Gray |



Figure 2.15.19 Example Circuit for 15 Colors by I Pin.


Figure 2.15.20 Background Function

Note: When the background function is enabled, the line enable the fringing function should not start with a blank character. If it starts with a blank character, a fringe is displayed to the left of the blank character.

### 2.15.5.5 OSD Display Screen Control

(1) Display on/off

This function is used to display characters specified for on/off display.

Display on/off specification unit: Display page
Display on/off specification register (1 bit) ......DON (Bit0 in ORDON)

| $" 0 "$ | $\ldots . . .$. | Disable display |
| :--- | :--- | :--- |
| "1" | ...... | Enable display |

Note: Do not start STOP mode during display is enable.
(2) Window function

This function is used to set upper and lower limit of display page. Window upper limit is specified by WVSH (ORWVSH). Window lower limit is specified by WVSL (ORWVSL). This function is enabled by setting EWDW (Bit1 in ORDON) in the OSD control register to 1 .

Window specification unit: Display page
Window function enable specification register (1 bit)...... EWDW (Bit1 in ORDON)
"0" ....... Disable window function "1" ....... Enable window function

Window upper limit specification register ( 9 bits) .....WVSH8 to 0 (ORWVSH)
Window lower limit specification register ( 9 bits)......WVSL8 to 0 (ORWVSL)
Window upper and lower limit position......
When VDSMD is " 0 " (Normal mode):

$$
\begin{aligned}
& \mathrm{WVSH}=(\mathrm{WVSH} 8 \text { to WVSH0 }) \mathrm{H} \times \mathrm{THD} \\
& \mathrm{WVSL}=(\mathrm{WVSL} 8 \text { to } \mathrm{WVSL} 0) \mathrm{H} \times \mathrm{T}_{\mathrm{HD}}
\end{aligned}
$$

When VDSMD is " 1 " (Double scan mode):

$$
\begin{aligned}
& \mathrm{WVSH}=(\mathrm{WVSH} 8 \text { to WVSH0 }) \mathrm{H} \times 2 \mathrm{THD} \\
& \mathrm{WVSL}=(\mathrm{WVSL} 8 \text { to WVSL0 }) \mathrm{H} \times 2 \mathrm{THD}
\end{aligned}
$$

Note 1: THD: One cycle of $\overline{\mathrm{HD}}$ signal
Note 2: WVSL $>$ WVSH $\geq$ " 1 "
Note 3: Modify the value of window upper and lower limit register and the value of EWDW during $\overline{\mathrm{VD}}$ signal is low.

Note 4: It is recommendable that the window function is always enabled (EWDW = " 1 ") and set WVSH to "01H", WVSL to "1FEH".

Note 5: Characters and symbols at scanning line specified by WVSL are not displayed.


Window display: On, Area plane display: On, Background color display: On, Raster plane display: On

## Correspond to Closed Caption



Figure 2.15.21 If WVSH is on a Code Plane
(3) Full-raster blanking function

Full-raster blanking function is used to color the entire background for the display area (TV screen). When using the full-raster blanking function, set YBLCS (Bit2 in ORP6S) to "1", output BL signal from Y/BL pin, because Y signal cannot delete whole display page from video signal.

This function is specified for each display page by setting EXBL (Bit6 in ORRCL) in the OSD register to " 1 ".

Full-raster blanking specification unit: Display page
Full-raster blanking enable register (1 bit) ..... EXBL (Bit6 in ORRCL)

$$
\begin{array}{lll}
" 0 " & . . . . . . & \text { Disable full-raster blanking } \\
" 1 " & . . . . . . & \text { Enable full-raster blanking }
\end{array}
$$

Full-raster blanking color specification ........ RCLI, RCLR, RCLG, RCLB registers ( 4 bits) (Bit3 to 0 in ORRCL)

I signal function select: PISEL (Bit6 in ORETC)
" 0 "
....... 15 colors specification
I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit.
" 1 " ....... 8 colors specification
Contents of RCLI register is disregarded.
I pin can be used as half transparency/half tone through an extra circuit.

Table 2.15.5.6 Raster Plane Color (15 colors)

| RCLI | RCLR | RCLG | RCLB | Raster Plane Color |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Blue |
|  | 0 | 1 | 0 | Green |
|  | 0 | 1 | 1 | Cyan |
|  | 1 | 0 | 0 | Red |
|  | 1 | 0 | 1 | Magenta |
|  | 1 | 1 | 0 | Yellow |
|  | 1 | 1 | 1 | White |
| 1 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Dark blue |
|  | 0 | 1 | 0 | Dark green |
|  | 0 | 1 | 1 | Dark cyan |
|  | 1 | 0 | 0 | Dark red |
|  | 1 | 0 | 1 | Dark magenta |
|  | 1 | 1 | 0 | Dark yellow |
|  | 1 | 1 | 1 | Gray |

(4) Area plane function

Area plane function is used to display square area to two points on a screen.
Two planes operate independently. They are displayed according to the priority (Area plane $1>$ Area plane 2).

See area plane display position setting in section 2.15.5.3 (2) how to set display positions for each area.

Each area plane is set to ON or OFF by AON2 and AON1 (Bit5 and bit4 in ORRCL).

Area plane colors are set by ACLIx, ACLRx, ACLGx, ACLBx (Bit7 to bit0 in ORACL, $\mathrm{x}: 1,2$ ).

Area plane colors: 8 or 15
Area plane specification unit: plane
Area plane color specification register (8 bits)
Area plane 1: ACLI1/ACLR1/ACLG1/ACLB1 (Bit3 to 0 in ORACL)
Area plane 2: ACLI2/ACLR2/ACLG2/ACLB2 (Bit7 to 4 in ORACL)

I signal function select: PISEL (Bit6 in ORETC)
" 0 " ....... 15 colors specification
I pin can be used to make a half level of $R$, $G$, $B$ signal (Dark color) through an extra circuit.
" 1 "
....... 8 colors specification
Contents of ACLI1 and ACLI2 register is disregarded.
I pin can be used as half transparency/half tone through an extra circuit.

Table 2.15.5.7 Area Plane Color (15 colors)

| ACLIX | ACLRx | ACLGx | ACLBx | Area Plane Color |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Blue |
|  | 0 | 1 | 0 | Green |
|  | 0 | 1 | 1 | Cyan |
|  | 1 | 0 | 0 | Red |
|  | 1 | 0 | 1 | Magenta |
|  | 1 | 1 | 0 | Yellow |
|  | 1 | 1 | 1 | White |
| 1 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Dark blue |
|  | 0 | 1 | 0 | Dark green |
|  | 0 | 1 | 1 | Dark cyan |
|  | 1 | 0 | 0 | Dark red |
|  | 1 | 0 | 1 | Dark magenta |
|  | 1 | 1 | 0 | Dark yellow |
|  | 1 | 1 | 1 | Gray |

$\mathrm{x}: 1,2$

I signal function select

1. Using for 15 colors $($ PISEL $=0)$


Figure 2.15.22 TV Display and OSD Signals (PISEL = 0)
2. Using for half transparency/half tone $($ PISEL $=1)$


Figure 2.15.23 TV Display and OSD Signals (PISEL = 1)
2.15.5.6 Interrupt Control
(1) Display line counter

The display line counter indicates number of display line (s) by OSD circuit on the TV screen. The display line counter is a 4-bit counter which is initialized to "0" by the falling edge of the $\overline{\mathrm{VD}}$ signal and which increments when last scanning of each display line is completed (Falling edge of the $\overline{\mathrm{HD}}$ signal). It is necessary to be read out display line counter several times, because it does not synchronize CPU clock.

Display line counter register ( 4 bits)..... DCTR (Bit3 to 0 in ORIRC)
" 0000 "......No display line is completed.
" $0001 "$...... 1st display line is completed.
" $0010 "$......2nd display line is completed.
" 1111 "..... 15th display line is completed.


Note 1: The display line counter also increments when a line with all blank characters or a line with display off is specified.
Note 2: When display lines are overlapped each other, previous display line is enabled and next line is canceled. At this time, the display line counter does not increment for canceled line.

Figure 2.15.24 Display Line Counter
(2) Interrupt generator circuit

An interrupt request is generated when a falling edge of $\overline{\mathrm{VD}}$ signal or when line counter (DCTR) is counted to the certain value specified by ISDC.

Interrupt source select register (1 bit) ...SVD (Bit4 in ORIRC)

| " 0 " $\ldots . .$. | Interrupt request generated when the display line <br> counter (DCTR) is counted to the certain value |
| :--- | :--- |
| which is specified by ISDC. |  |

Interrupt generation line specification register (4 bits) ... ISDC (Bit3 to 0 in ORIRC)
"0000" ....... Interrupt request generated when the display line counter is cleared.
"0001" ....... Interrupt request generated at end points of the last scanning line of the first display line
"0010" ....... Interrupt request generated at end points of the last scanning line of the 2 nd display line
"1111" ....... Interrupt request generated at end points of the last scanning line of the 15 th display line

### 2.15.5.7 Display Memory Access

(1) Display memory

The display memory is accessed for two purposes, one for writing data to the display memory, and one for reading data from the display memory.
Display memory address specification registers .... DMA8 to MDA0 (ORDMA) (9 bits)
Display memory data write registers
Character code write register (9 bits) .... CRA8 to CRA0 (ORCRA)
Character ornamentation data write registers .... SLNT, EUL, BLF, IDT, RDT, (7 bits) GDT, and BDT (ORDSN)

Display memory bank select register MBK (bit 1 in ORETC)
" 0 " ... When writing either character code or character ornamentation data
" 1 " ... When writing both character code and character ornamentation data
Note 1: These control registers have a characteristic that immediately when a value is written to the register, the content of the register is transferred as valid data to the OSD circuit/display memory.
Note 2: The data written to the display memory takes effect at the same time it is written. When character code or character ornamentation data is written to the display memory while it is displaying some character, the character may not be displayed correctly. When writing data to the display memory, make sure no character is being displayed in the memory location where you are going to write data.
Note 3: When writing data to or reading data from the display memory, do not use two-byte transfer instructions such as "LDW(HL),mn LD rr, (pp)". Otherwise, erroneous data may be written to the display memory or data may be written to an incorrect address.
Note 4: Allow for at least two instruction cycles between a display memory address write instruction and a data write or read instruction. Also, when continuous writing data to or reading data from the display memory, allow for at least two instruction cycles between one write or read instruction and the next. Otherwise, erroneous data may be written to the display memory or data may be written to an incorrect address.
Note 5: When setting display memory addresses, always be sure to write all of 9 address bits sequentially in order of DMA8 and DMA7 to DMA0.

1. Normal mode

In normal mode, the display memory addresses are automatically incremented each time data is read from or written to the memory. Because addresses are automatically incremented, this mode may be used for reading from or writing data to multiple continuous addresses simultaneously.
<Display memory write sequence in normal mode>
a. When writing either character code or character ornamentation data
(1) Set MFYWR, MBK, and RDWRV all to 0.
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Writing character code or character ornamentation data

- Writing character code

Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 through CRA0. At this point in time, the 9 bits of character code written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.

- Writing character ornamentation data

Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.
(4) To write data (character code or character ornamentation data) to continuous addresses, repeat step (3).
b. When writing character code and character ornamentation data at a time
(1) Set MFYWR to 0 , MBK to 1 , and RDWRV to 0 .
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation written are transferred to the display memory.
(4) Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written and the character ornamentation data written in step (3) are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.
(5) To write data to continuous addresses, repeat steps (3) and (4).
<Display memory read sequence in normal mode>
a. When reading either character code or character ornamentation data
(1) Set MFYWR to 0, MBK to 0, and RDWRV to 1.
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Reading character code or character ornamentation data

- Reading character code

Read the most significant bit of character code to CRA8. Go on and read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are automatically incremented.

- Reading character ornamentation data

Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, DMA8 through DMA0 are automatically incremented.
(4) To read data (character code or character ornamentation data) from continuous addresses, repeat step (3).
b. When reading character code and character ornamentation data at a time
(1) Set MFYWR to 0 , MBK to 1 , and RDWRV to 1.
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT.
(4) Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are automatically incremented.
(5) To read data from continuous addresses, repeat steps (3) and (4).
2. Read-modify-write mode

When writing data in read-modify-write mode, the display memory addresses are automatically incremented as in normal mode, but when reading data in this mode, the memory addresses are not automatically incremented.

Therefore, immediately after executing a read from some display memory address, you can execute a write to the same display memory address. After executing a write, the display memory addresses are automatically incremented.
a. Reading/writing either character code or character ornamentation data in read-modify-write mode
(1) Set MFYWR to 1 and MBK to 0, and RDWRV to 1.
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Reading character code or character ornamentation data

- Reading character code

Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. DMA8 to DMA0 are not incremented.

- Reading character ornamentation data

Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. DMA8 to DMA0 are not incremented.
(4) Writing character code or character ornamentation data

- Set RDWRV to " 0 ".
- Writing character code

Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.

- Writing character ornamentation data

Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.
(5) To continue executing read-modify-write operations, repeat steps (1) to (4). To read/write data (Character code or character ornamentation data). To continue executing read-modify-write mode from continuous addresses, repeat steps (3) and (4).
b. Reading/writing both character code and character ornamentation data in read-modify-write mode
(1) Set MFYWR to 1 , MBK to 1 and RDWRV to 1
(2) Write the most significant address bit of the display memory to DMA8. Go on and write the 8 low-order address bits of the display memory to DMA7 to DMA0.
(3) Read character ornamentation data SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, DMA8 to DMA0 are not incremented.
(4) Read the most significant bit of character code to CRA8. Read the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, DMA8 to DMA0 are not incremented.
(5) Set RDWRV to " 0 ".
(6) Write character ornamentation data to SLNT, EUL, BLF, IDT, RDT, GDT, and BDT. At this point in time, the character ornamentation data written is transferred to the display memory.
(7) Write the most significant bit of character code to CRA8. Go on and write the 8 low-order bits of character code to CRA7 to CRA0. At this point in time, the 9 bits of character code written and the character ornamentation data written in step (6) are transferred to the display memory, and DMA8 to DMA0 are automatically incremented.
(8) To continue executing read-modify-write operations, repeat steps (1) to (7). (To read/write data to and from continuous addresses in read-modify-write mode, repeat steps (3) to (7).)

Table 2.15.5.8 Address Increment

|  |  | RD (RDWRV = 1) |  | WR (RDWRV = 0) |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Character <br> Ornamentation | Character <br> Code | Character <br> Ornamentation | Character <br> Code |
|  | MBK $=0$ | INC | INC | INC | INC |
|  | MBK $=1$ | - | INC | - | INC |
| MFYWR $=1$ | MBK $=0$ | - | - | INC | INC |
|  | MBK $=1$ | - | - | - | INC |

INC: Automatic address increment at read or write.
-: No address change at data read or write.

Example: $\quad$ Setting a character code ( 020 H ) to the display memory (Address: 120 H ) and setting ( 001 H ) for a character ornamentation.

1. $\mathrm{MBK}=0$ ; Set display memory address

LD (0x25), 0x01 ; ORDMA<DMA8>
LD (0x24), 0x20 ; ORDMA[DMA7:0](DMA7:0) ; Set character code
LD ( $0 \times 1 \mathrm{~F}$ ), $0 \times 00$; ORCRA<CRA8>

LD (0x1E), 0x20 ; ORCRA[CRA7:0](CRA7:0) ; Set display memory address again
LD (0x25), 0x01
LD (0x24), 0x20
; Set character ornamentation
LD (0x1D), 0X01 ; ORDSN<SLNT, .... BDT>
2. $M B K=1$
; Set display memory address

| LD | $(0 \times 25)$, | $0 \times 01$ |
| :--- | :--- | :--- |
| LD | $(0 \times 24)$, | $0 \times 20$ |

; Set character ornamentation
LD (0x1D), 0X01
; Set character code

| LD | $(0 \times 1 \mathrm{~F})$, | $0 \times 00$ |
| :--- | :--- | :--- |
| LD | $(0 \times 1 \mathrm{E})$, | $0 \times 20$ |

Note 1: To write character code into the display memory, first write into register CRA8 and then write into registers CRA7 to CRA0. When data is written into registers CRA7 to CRA0, DMA8 to DMA0 is incremented. It is impossible to write into the display memory for CRA7 to CRA0 alone. If no data is written into register CRA8 while data is written into registers CRA7 to CRA0, the value previously written into register CRA8 is written into the associated display memory.

Note 2: To read character code from the display memory, first read from register CRA8, and then read from registers CRA7 to CRA0. When data is read from registers CRA7 to CRA0, DMA8 to DMA0 is incremented.

Note 3: There should be a time interval of at least two machine cycles between a DMA set instruction and a data write/read instruction. There should be a time interval of at least two machine cycles between a data write instruction and a data read instruction.
(2) Character

Characters: 384 (including blank character)
Character specification register (9 bits) ........... CRA8 to CRA0 (Bit8 to 0 in ORCRA)
Character code " 000 H " ..........................................ank character
Character code " 001 H " to " $017 \mathrm{FH} " . . . . .$. User programmable by character ROM
(3) Character color

Character colors: 8 or 15
Character color specification unit: Character
Character color specification register (4 bits): IDT/RDT/GDT/BDT (Bit3 to 0 in ORDSN)

I signal function select: PISEL (Bit6 in ORETC)
"0"

15 colors specification
I pin can be used to make a half level of R, G, B signal (Dark color) through an extra circuit.
....... 8 colors specification
Contents of IDT register is disregarded.
I pin can be used as half transparency/half tone through an extra circuit.

Table 2.15.5.9 Character Color (15 colors)

| IDT | RDT | GDT | BDT | Character Color |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Blue |
|  | 0 | 1 | 0 | Green |
|  | 0 | 1 | 1 | Cyan |
|  | 1 | 0 | 0 | Red |
|  | 1 | 0 | 1 | Magenta |
|  | 1 | 1 | 0 | Yellow |
|  | 1 | 1 | 1 | White |
| 1 | 0 | 0 | 0 | Black |
|  | 0 | 0 | 1 | Dark blue |
|  | 0 | 1 | 0 | Dark green |
|  | 0 | 1 | 1 | Dark cyan |
|  | 1 | 0 | 0 | Dark red |
|  | 1 | 0 | 1 | Dark magenta |
|  | 1 | 1 | 0 | Dark yellow |
|  | 1 | 1 | 1 | Gray |



Figure 2.15.25 Example of Circuit for 15 Color by I Pin
(4) Blinking function

Blinking function is used to blink display characters.
When BKMF is " 1 ", characters specified for blinking by BLF are not displayed. (If the background color function is used, the background color is not disappeared.)

Blinking specification unit: Character
Blinking specification register (1 bit)..... BLF (Bit4 in ORDSN)

$$
\begin{array}{lll}
" 0 " & \text {....... } & \text { No blinking } \\
" 1 " & \text {...... } & \text { Blinking }
\end{array}
$$

Blinking master specification register (1 bit) ..... BKMF (Bit5 in ORETC)

$$
\begin{array}{lll}
" 0 " & . . . . . . & \text { Disable blinking } \\
\text { "1" } & \text {...... } & \text { Enable blinking (Characters whose BLF are set to } \\
& & \text { "1" are not displayed.) }
\end{array}
$$

Note: Regarding the extra dot of the left and/or right character by fringing function, it is not enabled as blink.
(5) Underline function

Underline function is used to add a line under a display character. The underline is same color as that of character.

Underline specification unit: Character/line
Underline enable register (Character unit) (1 bit).....EUL (Bit5 in ORDSN)

$$
\begin{array}{lll}
" 0 " & \text {....... } & \text { No underline } \\
" 1 " & \text {....... Underline }
\end{array}
$$

Underline enable register (Line unit) (1 bit $\times 12$ ) ......EULAn (n: 1 to 8)(OREULA8), EULAn (n: 9 to 12) (OREULA12)
Underline colors: 8 or 15
Underline color specification registers (4 bits) ......RDT, GDT, BDT, IDT (Bit3 to 0 in ORDSN) (Refer to Table 2.15.5.9)

Note: To use the underline function, set both the underline enable register for underlining text in characters and that for underlining text in lines. If the former register (EUL) only is set, an underline is not displayed.


Figure 2.15.26 Underline
(6) Solid space control

Solid space control is used to display one column of solid space to the left and right of 32 columns.

Solid space control is used to delete the video signal in the areas where solid spaces are located in the original display page, then add color to them.

Solid space specification unit: line
Solid space specification register (24 bits)

| For line 1 | SOL11 and SOL10 (Bits 1 and 0 in ORSOL4) |
| :---: | :---: |
| For line 2 | SOL21 and SOL20 (Bits 3 and 2 in ORSOL4) |
| $\vdots$ | $\vdots$ |
| For line 12 | SOL121 and SOL120 (Bits 7 and 6 in ORSOL12) |

Solid space specification
The solid space control functions as follows:
SOLx1/SOLx0 (x: 1 to 12)
"00" ....... No solid space display
"01" ....... Solid space display left for 32 columns
"10" ....... Solid space display right for 32 columns
"11" ....... Solid space display left and right for 32 columns
Solid space color specification registers (4 bits)
....... IBDT, RBDT, GBDT, BBDT (Bits 3 to 0 in ORBK)
(Same color as that of background)


Figure 2.15.27 Solid Space
(7) Slant function

Slant function is used to slant characters for italics.

Slant specification unit: Character
Slant enable register (1 bit) .....SLNT (Bit6 in ORDSN)

$$
\begin{array}{lll}
" 0 " & \text {....... No slant } \\
" 1 " & \text {...... } & \text { Slant }
\end{array}
$$

Note 1: SLANT function is enabled each characters, and therefore, in case of using background function, this color of the Background is enable as slant. Regarding the extra dots of the left and/or right character by fringing function, it is not enabled as slant.
Note 2: When a character is slanted in an area, which overlaps with the character field, the overlap is also slanted.
Note 3: If slanting a character causes part of the character to get into the character field to the immediate right of the character, then this part is not displayed.
Note 4: To provide closed caption display (CCD), specify black as the background color, and set YBLCS to " 1 ". R, G, B and $Y$ are all slanted. Thus, if the $Y$ signal is selected, a video signal is displayed above and to the left of the slant character.
Note 5: When a character is slanted, the dot data to the immediate left of the character is also slanted.


When an entire character field (including its background) contains dots:


Figure 2.15.28 Slant

### 2.15.5.8 OSD Control Registers

Can not access all OSD control registers in any of read-modify-write instructions such as bit operation, etc.

| ORHS1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (Initial value: 0000 0000) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00F81H) | HS17 | HS16 | HS15 | HS14 | HS13 | HS12 | HS11 | HS10 |  |  |
|  | Horizontal display start position specification |  |  |  |  |  |  |  |  | Write only |


| ORVS1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00F82H) | VS17 | VS16 | VS15 | VS14 | VS13 | VS12 | VS11 | VS10 |
| (00F83H) |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  | VS28 |  |  |  |  |  |  |  |
| ORVS3 <br> (00F86H) | VS37 | VS36 | VS35 | VS34 | VS33 | VS32 | VS31 | VS30 |
| (00F87H) | VS38 |  |  |  |  |  |  |  |
| ORVS4 <br> (00F88H) | VS47 | VS46 | VS45 | VS44 | VS43 | VS42 | VS41 | VS40 |
| (00F89H) |  |  |  |  |  |  |  |  |

ORVS5 (00F8AH) (00F8BH) ORVS6 (00F8CH) (00F8DH)
ORVS7 (00F8EH) (00F8FH)
ORVS8 (00F90H) (00F91H) ORVS9 (00F92H) (00F93H) ORVS10 (00F94H) (00F95H) ORVS11 (00F96H) (00F97H) ORVS12 (00F98H) (00F99H)

| VS57 | VS56 | VS55 | VS54 | VS53 | VS52 | VS51 | VS50 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - |  |  |  |  |  |  | VS58 |


| VS67 | VS66 | VS65 | VS64 | VS63 | VS62 | VS61 | VS60 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | - | vS68 |


| VS77 | VS76 | VS75 | VS74 | VS73 | VS72 | VS71 | VS70 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | VS78 |


| VS87 | VS86 | VS85 | VS84 | VS83 | VS82 | VS81 | VS80 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | - | VS88 |


| VS97 | VS96 | VS95 | VS94 | VS93 | VS92 | VS91 | VS90 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | - | VS98 |


| VS107 | VS106 | VS105 | VS104 | VS103 | VS102 | VS101 | VS100 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | - | - | - | VS108 |


| VS117 | VS116 | VS115 | VS114 | VS113 | VS112 | VS111 | VS110 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | VS118 |


| VS127 | VS126 | VS125 | VS124 | VS123 | VS122 | VS121 | VS120 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | VS128 |

(Initial value: 0000 0000) (Initial value: **** ***0)
(Initial value: 0000 0000) (Initial value: ${ }^{* * * * ~ * * * 0) ~}$
(Initial value: 0000 0000) (Initial value: ${ }^{* * * * ~ * * * 0) ~}$
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: ${ }^{* * * * ~ * * * 0) ~}$
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)
(Initial value: 0000 0000)
(Initial value: **** ***0)

| VSn8 to <br> VSn0 | Vertical display start position for line n | Write <br> only |
| :---: | :--- | :---: |

Note 1: If display lines are overlapped each other, previous display line is enabled and next line is disabled. Set the vertical display start position not to overlap display lines.

Note 2: Transfer the contents of vertical display start position registers into OSD circuit before a position of the scanning line coincides with their own vertical display start position.


| OREULA8 <br> (00F9DH) <br> OREULA12 <br> (00F9EH) | EULA8 | EULA7 | EULA6 | EULA5 | EULA4 | EULA3 | EULA2 | EULA1 | (Initial value: 0000 0000) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | - | - | - | - | EULA12 | EULA11 | EULA10 | EULA9 | (Initial value: **** 0000) |
|  | EULAn | Underline for display line for line n |  |  |  | 1: Display on |  |  |  |


| OREFR8 <br> (00F9FH) <br> OREFR12 <br> (00FAOH) | EFR8 | EFR7 | EFR6 | EFR5 | EFR4 | EFR3 | EFR2 | EFR1 | (Initial value: 0000 0000) <br> (Initial value: **** 0000) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | - | - | - | - | EFR12 | EFR11 | EFR10 | EFR9 |  |  |  |
|  | EFRn | Fringing enable specification register for line n |  |  |  | $0:$ Disable fringing <br> 1: Enable fringing |  |  |  |  | Write only |
|  |  |  |  |  |  |  |  |  | (n: 1 to 12) |  |  |

Note: When a display line is enabled fringing function, its vertical size is increased by one dot (by two dots when its character size is small) independent of its character font. Therefore, when a vertical display start position is specified to no space between the lines, the display line which is overlapped with increasing dot(s) is canceled.
ORSLO4

(n: 0 to 12)


Note: Set IBDT and IFDT to 1 when PISEL (Bit6 in ORETC) sets to 1. Then background color select and fringing color select are 8 variety.

| ORACL | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (Initial value: 0000 0000) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FA6H) | ACLI2 | ACLR2 | ACLG2 | ACLB2 | ACLI1 | ACLR1 | ACLG1 | ACLB1 |  |  |
|  | ACLI2/ <br> ACLR2/ <br> ACLG2/ <br> ACLB2 | Area 2 plane color select |  |  |  | 0000: Black <br> 0001: Blue <br> 0010: Green <br> 0011: Cyan <br> 0100: Red <br> 0101: Magenta <br> 0110: Yellow <br> 0111: White <br> 1000: Black <br> 1001: Dark blue <br> 1010: Dark green <br> 1011: Dark cyan <br> 1100: Dark red <br> 1101: Dark magenta <br> 1110: Dark yellow <br> 1111: Gray |  |  |  | Write only |
|  | ACLII/ <br> ACLR1/ <br> ACLG1/ <br> ACLB1 | Area 1 plane color select |  |  |  | 0000: Black <br> 0001: Blue <br> 0010: Green <br> 0011: Cyan <br> 0100: Red <br> 0101: Magenta <br> 0110: Yellow <br> 0111: White <br> 1000: Black <br> 1001: Dark blue <br> 1010: Dark green <br> 1011: Dark cyan <br> 1100: Dark red <br> 1101: Dark magenta <br> 1110: Dark yellow <br> 1111: Gray |  |  |  |  |
|  | ACLI2 |  |  |  |  | 0: Not assign half transparency for area 2 plane <br> 1: Assign half transparency for area 2 plane |  |  |  |  |
|  | ACLI1 |  |  |  |  | 0: Not assign half transparency for area 1 plane <br> 1: Assign half transparency for area 1 plane |  |  |  |  |

Note: Set ACLI2 and ACLI1 to 1 when PISEL (Bit6 in ORETC) sets to 1. Then area 2 plane color select and area 1 plane color select are 8 variety.



Note: Write or read CRA7 to CRA0 after write or read CRA8.



| ORDON | 7 | 6 5 4 | 2 | 1 | 0 | (Initial value: **** *000) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00F80H) | - | - - - | RGWR | EWDW | DON |  |  |
|  | RGWR | Written data transfer control | 0: (Initial state) <br> 1: Transfers written data to OSD circuit (after transfer, RGWR is reset to 0 ) |  |  |  | Read/ Write |
|  | EWDW | Window enable specification register | 0 : Disable window function <br> 1: Enable window function |  |  |  |  |
|  | DON | Display on/off select | 0: Disable display <br> 1: Enable display |  |  |  |  |



Note: $\quad$ Set RCLI to 1 when PISEL (Bit6 in ORETC) sets to 1 . Then transfer plane select is 8 variety.

| ORAHS1 | 7 | 6 |  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FA8H) | AHS17 | AHS1 |  | AHS15 | AHS14 | AHS13 | AHS12 | AHS11 | AHS10 | (Initial value: 0000 0000) <br> (Initial value: *******0) |  |  |
| (00FA9H) | - |  |  | - |  |  |  | - | AHS18 |  |  |  |
| ORAHE1 (00FAAH) | AHE17 | AHE1 |  | AHE15 | AHE14 | AHE13 | AHE12 | AHE11 | AHE10 | (Initial value: 0000 0000) |  |  |
| (00FABH) | - | - |  | - |  |  |  | - | AHE18 | (Initial value: | *******0) |  |
|  | AHS1 |  | Horizontal start point for area 1 plane |  |  |  |  |  |  |  |  | Write only |
|  | AHE1 |  | Horizontal end point for area 1 plane |  |  |  |  |  |  |  |  |  |

( $\mathrm{n}: 0$ to 8 )

ORAVS1
(00FACH) (OOFADH)

| AVS17 | AVS16 | AVS15 | AVS14 | AVS13 | AVS12 | AVS11 | AVS10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | AVS18 |

(Initial value: 0000 0000) (Initial value: **** *** 0 )

ORAVE1
(00FAEH) (00FAFH)

(Initial value: 0000 0000)
(Initial value: ${ }^{* * * * * * * 0) ~}$

| AVS1n | Vertical start point for area 1 plane | Write |
| :---: | :--- | :---: |
| AVE1n | Vertical end point for area 1 plane | only |

( $\mathrm{n}: 0$ to 8 )

ORAHS2
(00FBOH)
(00FB1H)
ORAHE2
(00FB2H) (00FB3H)

| AHS27 | AHS26 | AHS25 | AHS24 | AHS23 | AHS22 | AHS21 | AHS20 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | AHS28 |


(Initial value: 0000 0000)
(Initial value: **** ***0)

| AHS2n | Horizontal start point for area 2 plane | Write |
| :---: | :--- | :---: |
| AHE2n | Horizontal end point for area 2 plane | only |

( $\mathrm{n}: 0$ to 8 )
(00FB4H) (00FB5H)

| AVS27 | AVS26 | AVS25 | AVS24 | AVS23 | AVS22 | AVS21 | AVS20 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-\ldots$ | - | - | - | - | - | - | AVS28 |

(Initial value: 0000 0000)
ORAVE2
(00FB6H)
(00FB7H)

(Initial value: 0000 0000)
(Initial value: **** ***0)

| AVS2n | Vertical start point for area 2 plane | Write |
| :---: | :--- | :---: |
| AVE2n | Vertical end point for area 2 plane | only |

(n: 0 to 8)


Note: Clear " 0 " to bit3 in ORETC.

ORIRC
(00FB9H)

(Initial value: ***0 0000)

| SVD | Interrupt source select | 0: Interrupt request by ISDC value <br> 1: Interrupt request at falling edge of $\overline{\mathrm{VD}}$ signal |  |
| :---: | :---: | :---: | :---: |
| ISDC | Interrupt generation line select | When the line display of the ISDC value ends (with the falling edge of $\overline{\mathrm{HD}}$ signal) <br> while $\operatorname{SVD}=0$, interrupt request is generated. <br> 0000: Request interrupt when display of low-order 4 bits "0000" of DCTR ends. <br> 0001: Low-order 4 bits "0001" of DCTR <br> 0010: Low-order 4 bits "0010" of DCTR <br> 0011: Low-order 4 bits "0011" of DCTR <br> 0100: Low-order 4 bits "0100" of DCTR <br> 0101: Low-order 4 bits "0101" of DCTR <br> 0110: Low-order 4 bits "0110" of DCTR <br> 0111: Low-order 4 bits "0111" of DCTR <br> 1000: Low-order 4 bits "1000" of DCTR <br> 1001: Low-order 4 bits "1001" of DCTR <br> 1010: Low-order 4 bits "1010" of DCTR <br> 1011: Low-order 4 bits "1011" of DCTR <br> 1100: Low-order 4 bits " 1100 " of DCTR <br> 1101: Low-order 4 bits " 1101 " of DCTR <br> 1110: Low-order 4 bits "1110" of DCTR <br> 1111: Low-order 4 bits " 1111 " of DCTR | Write only |

ORIRC
(00FB9H)

| - | - - - | DCTR (Initial value: **** 0000) | (Initial value: **** 0000) |
| :---: | :---: | :---: | :---: |
| DCTR | Display line counter | 0000: No line display or when the display of the 16th line ends. <br> 0001: 1st line display ends. <br> 0010: 2nd line display ends. <br> 0011: 3rd line display ends. <br> 0100: 4th line display ends. <br> 0101: 5th line display ends. <br> 0110: 6th line display ends. <br> 0111: 7th line display ends. <br> 1000: 8th line display ends. <br> 1001: 9th line display ends. <br> 1010: 10th line display ends. <br> 1011: 11th line display ends. <br> 1100: 12th line display ends. <br> 1101: 13th line display ends. <br> 1110: 14th line display ends. <br> 1111: 15th line display ends. | Read only |

Note 1: The display line counter also increments when a line with all blank data or a line with display off is specified. If display lines are overlapped each other, previous display line is enabled and next line is disabled. At this time, the display line counter for canceled line does not increment.

Note 2: *: Don't care.
Note 3: All OSD control registers cannot use the read-modify-write instructions. (Bit manipulation instructions such as SET, CLR, etc. and logical operation such as AND, OR, etc.)

Table 2.15.5.10 OSD Control Register List (1/2)

| Register Address | Register Name | Register Bit Configuration |  |  |  |  |  |  |  | Bit Contents |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
| 00F81 | ORHS1 | HS17 | HS16 | HS15 | HS14 | HS13 | HS12 | HS11 | HS10 | HS17 to 10: Code horizontal display base position setting |
| 00F82, | ORVSn | VSn7 | VSn6 | VSn5 | VSn4 | VSn3 | VSn2 | VSn1 | VSn0 | VSn8 to 0: Code vertical display position setting (n: 0 to 12) |
| 00F83 to 00F98, 00F99 |  | - | - | - | - | - | - | - | VSn8 |  |
| 00F9A | ORCS4 | CS4 |  | CS3 |  | CS2 |  | CS1 |  | CSn: Character size (n: 1 to 12 )  <br> 00: Display off 10: Middle size <br> 01: Large size 11: Small size |
| 00F9B | ORCS8 | CS8 |  | CS7 |  | CS6 |  | CS5 |  |  |
| 00F9C | ORCS12 | CS12 |  | CS11 |  | CS10 |  | CS9 |  |  |
| 00F9D | OREULA8 | EULA8 | EULA7 | EULA6 | EULA5 | EULA4 | EULA3 | EULA2 | EULA1 | EULAn: Underline display setting for line n ( $\mathrm{n}: 0 \mathrm{O}$ to 12) |
| 00F9E | OREULA12 | - | - | - | - | EULA12 | EULA11 | EULA10 | EULA9 |  |
| 00F9F | OREFR8 | EFR8 | EFR7 | EFR6 | EFR5 | EFR4 | EFR3 | EFR2 | EFR1 | EFRn: Fringing setting for line n (n: 0 to 12) |
| 00FAO | OREFR12 | - | - | - | - | EFR12 | EFR11 | EFR10 | EFR9 |  |
| 00FA1 | ORCLKF | CK7 | CK6 | CK5 | CK4 | CK3 | CK2 | CK1 | CKO | CKx: Display clock frequency monitor (x: 0 to 7) |
| 00FA1 | ORCLKC | CKC7 | CKC6 | CKC5 | CKC4 | CKC3 | CKC2 | CKC1 | CKC0 | CKCx: Display clock frequency (x: 0 to 7) |
| 00FA2 | ORSOL4 | SOL4 |  | SOL3 |  | SOL2 |  | SOL1 |  | SOLn: Solid space display setting for line $\mathrm{n}(\mathrm{n}: 0$ to 12)00: No solid space 10: Right <br> 01: Left 11: Left and right |
| 00FA3 | ORSOL8 |  |  |  |  |  |  |  |  |  |
| 00FA4 | ORSOL12 | SOL12 |  | SOL11 |  | SOL10 |  | SOL9 |  |  |
| 00FA5 | ORBK | IBDT | RBDT | GBDT | BBDT | IFDT | RFDT | GFDT | BFDT | IBDT, RBDT, GBDT, BBDT: Background color setting IFDT, RFDT, GFDT, BFDT: Fringing color setting |
| 00FA6 | ORACL | ACLI2 | ACLR2 | ACLG2 | ACLB2 | ACLI1 | ACLR1 | ACLG1 | ACLB1 | ACLI2/ACLR2/ACLG2/ACLB2: Area 2 plane color ACLI1/ACLR1/ACLG1/ACLB1: Area 1 plane color Set ACLI2 and SCLI1 to 1, when PISEL 1 |
| 00FA7 | CRRCL | EBKGD | EXBL | AON2 | AON1 | RCLI | RCLR | RCLG | RCLB | EBKGD: Background function EXBL: Full-raster blanking AON2: Area 2 plane display AON1: Area 1 plane display RCLI/R/G/B: Raster plane color Set RCLI to 1 , when PISEL 1 |
| 00FA8 | ORAHS1 | AHS17 | AHS16 | AHS15 | AHS14 | AHS13 | AHS12 | AHS11 | AHS10 | AHSx: Area 1 plane horizontal start position (n: 0 to 8) |
| 00FA9 |  | - | - | - | - | - | - | - | AHS18 |  |
| OOFAA | ORAHE1 | AHE17 | AHE16 | AHE15 | AHE14 | AHE13 | AHE12 | AHE11 | AHE10 | AHE1x: Area 1 plane horizontal end position (n: 0 to 8) |
| 00FAB |  | - | - | - | - | - | - | - | AHE18 |  |
| 00FAC | ORAVS1 | AVS17 | AVS16 | AVS15 | AVS14 | AVS13 | AVS12 | AVS11 | AVS10 | AVS1x: Area 1 plane vertical start position (n: 0 to 8) |
| OOFAD |  | - | - | - | - | - | - | - | AHS18 |  |
| OOFAE | ORAVE1 | AVE17 | AVE16 | AVE15 | AVE14 | AVE13 | AVE12 | AVE11 | AVE10 | AVE1x: Area 1 plane vertical end position (n: 0 to 8) |
| OOFAF |  | - | - | - | - | - | - | - | AVE18 |  |
| 00FB0 | ORAHS2 | AHS27 | AHS26 | AHS25 | AHS24 | AHS23 | AHS22 | AHS21 | AHS20 | AHS2x: Area 2 plane horizontal start position ( n : 0 to 8) |
| 00FB1 |  | - | - | - | - | - | - | - | AHS28 |  |
| 00FB2 | ORAHE2 | AHE27 | AHE26 | AHE25 | AHE24 | AHE23 | AHE22 | AHE21 | AHE20 | AHE2x: Area 2 plane horizontal end position (n: 0 to 8) |
| 00FB3 |  | - | - | - | - | - | - | - | AHE28 |  |
| 00FB4 | ORAVS2 | AVS27 | AVS26 | AVS25 | AVS24 | AVS23 | AVS22 | AVS21 | AVS20 | AVS2x: Area 2 plane vertical start position (n: 0 to 8) |
| 00FB5 |  | - | - | - | - | - | - | - | AHS28 |  |
| 00FB6 | ORAVE2 | AVE27 | AVE26 | AVE25 | AVE24 | AVE23 | AVE22 | AVE21 | AVE20 | AVE2x: Area 2 plane vertical end position (n: 0 to 8) |
| 00FB7 |  | - | - | - | - | - | - | - | AVE28 |  |
| 00FB8 | ORETC | VDSMD | PISEL | BKMF | ESMZ | "0" | MFYWR | MBK | RDWRV | VDSMD: Scan mode select <br> PISEL: I pin function select <br> BKMF: Blinking master <br> ESMZ: Smoothing <br> MFYWR: Display memory read mode select MBK: Display memory bank switching select RDWRV: Read/write mode select at normal mode |
| 00FB9 | ORIRC | - | - | - | SVD | ISDC |  |  |  | SVD: Interrupt source select ISDC: Interrupt generation line select |
| 00FB9 | ORIRC | - | - | - | - |  |  |  |  | DCTR: Display line counter |
| 00FBA | ORP6S | P67S | P66S | P65S | P64S | PIDS | YBLCS |  |  | P6xS: P6 port output select ( $\mathrm{x}: 4$ to 7 ) <br> PIDS: I pin output select <br> YBLCS: Y/BL signal select <br> MPXS: R, G, B, Y/BL single select |

Table 2.15.5.11 OSD Control Register List (2/2)

| Register Address | Register Name | Register Bit Configuration |  |  |  |  |  |  |  | Bit Contents |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
| 00FBB | ORIV | VDPOL | HDPOL | YBLII | RGBII | YIV | BLIV | RGBIV | IIV | VDPOL: $\overline{\mathrm{VD}}$ input polarity select HDPOL: $\overline{H D}$ input polarity select YBLII: Y/BLIN input polarity select RGBII: RIN, GIN, BIN input select YIV: Y output polarity select BLIV: BL output polarity select RGBIV: R, G, B output polarity select IIV: I pin polarity select |
| 00024 | ORDMA | DMA7 | DMA6 | DMA5 | DMA4 | DMA3 | DMA2 | DMA1 | DMAO | DMAx: Display memory address setting (x: 0 to 8) |
| 00025 |  | - | - | - | - | - | - | - | DMA8 |  |
| 0001D | ORDSN | - | SLNT | EUL | BLF | IDT | RDT | GDT | BDT | SLNT: Slant EUL: Underline <br> BLF: Blinking IDT/RDT/CDT/BDT: Character color |
| 0001 E | ORCRA | CRA7 | CRA6 | CRA5 | CRA4 | CRA3 | CRA2 | CRA1 | CRAO | CRAx: Character code (x: 0 to 8) |
| 0001F |  | - | - | - | - | - | - | - | CRA8 |  |
| 00FBC | ORWVSH | WVSH7 | WVSH6 | WVSH5 | WVSH4 | WVSH3 | WVSH2 | WVSH1 | WVSH0 | WVSHx: Window upper limit position (x: 0 to 8) |
| 00FBD |  | - | - | - | - | - | - | - | WVSH8 |  |
| 00FBE | ORWVSI | WVSL7 | WVSL6 | WVSL5 | WVSL4 | WVSL3 | WVSL2 | WVSL1 | WVSLO | WVSL: Window lower limit position (x: 0 to 8) |
| 00FBF |  | - | - | - | - | - | - | - | WVSL8 |  |
| 00F80 | ORDON | - | - | - | - | - | RGWR | EWDW | DON | RGWR: Writing data transfer control EWDW: Window enable DON: OSD display on/off |

Note 1: Except the meshed registers are changed by RGWR.
Note 2: Only lower 2 bits of the register in address 00 F 80 H are changed by RGWR (the register in address 00F80H must not be used with any of the read-modify-write instructions as SET, CLR, etc.).

### 2.16 Jitter Elimination Circuit

The TMP88CS38B/CM38B/CP38B has a built-in jitter elimination circuit which maintains the vertical stability of the OSD even when input of the vertical signal fluctuates.

And the field decision information for the OSD circuit is detected by using jitter elimination circuit.

### 2.16.1 Configuration



Figure 2.16.1 Jitter Elimination Circuit

### 2.16.2 Control

Jitter elimination circuit is controlled by the jitter elimination control register (JECR).
Jitter Elimination Control Register

| JECR | 7 | 6 5 4 | 32 |  |  | 0 | ***0 0000) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FE4H) | -- | VDSEL | AFLD | JEEN |  | "0"- (Initial va |  |  |
|  | VDSEL | VD select |  |  |  | $\overline{\mathrm{VD}}$ from P71 <br> $\overline{\mathrm{VD}}$ from jitter elimination circuit |  | Write only |
|  | AFLD | Automatic field decision |  |  | $\begin{aligned} & 0: \\ & 1: \end{aligned}$ | Automatic field decision disabled Automatic field decision enabled |  |  |
|  | JEEN | Jitter elimination enable specification |  |  | 0: | Jitter elimination disabled Jitter elimination enabled |  |  |

Note 1: Clear the AFLD to " 0 " to disable jitter elimination circuit.
Note 2: Always clear " 0 " to bit1 and bit0 of JECR.
Note 3: Clear " 0 " to AFLD and VDSEL if there is no phase shift in the vertical and horizontal sync. signals every other time, such as with non-interlaced TV.
Note 4: *: Don't care
Note 5: Setting JEEN to "0", OSD display is only 2nd field.
Note 6: Setting AFLD to "0", OSD display is only 2 nd field.
Jitter Elimination Status Register


| FDSF | Field detect status flag | 0: A position of a scanning line exists in the field which has a second display dot of character on an interlace TV screen. <br> 1: A position of a scanning line exists in the field which has a first display dot of character on an interlace TV screen. |  |
| :---: | :---: | :---: | :---: |
| PDF2 to PDFO | Phase detect flag between $\overline{\mathrm{HD}}$ and $\overline{\mathrm{VD}}$ | 000: Phase 0 <br> 001: Phase 1 <br> 010: Phase 2 <br> 011: Phase 3 <br> 100: Phase 4 <br> 101: Phase 5 <br> 110: Phase 6 <br> 111: Phase 7 | Read only |

Note 1: FDSF is different from the 1st and the 2nd field. It is a unique field decided for OSD display.
Note 2: *: Don't care.
Note 3: $\overline{\mathrm{HD}}$


Figure 2.16.2 Jitter Elimination Control Register and Jitter Elimination Status Register

### 2.16.3 Jitter Elimination Mode

The jitter elimination circuit is to identify the phase of the falling edges of the external $\overline{\mathrm{VD}}$ signal and $\overline{\mathrm{HD}}$ signal. When $\overline{\mathrm{VD}}$ signal is falling within $\overline{\mathrm{HD}}$ signal falling $+/-1 / 4 \mathrm{HD}$, the jitter is automatically eliminated and internal $\overline{\mathrm{VD}}$ signal is set to the stable location.

This function is enabled by setting JEEN (Bit2 in JECR) in the jitter elimination control register to " 1 ".

### 2.16.4 Auto Field Line Decision

The internal vertical and horizontal sync. signals corrected by the jitter elimination circuit generate the field line decision signals used in the OSD.

The OSD display in normal mode

Type A) When the OSD circuit is used on the TV system which has a phase shift in the vertical and horizontal sync. Signals every other filed such as the interlace TV, enable jitter elimination circuit and set " 1 " to AFLD and VDSEL. At this time, the field lines which have first and second display dot of character are displayed.

Type B) When the OSD circuit is used on the TV system which has no phase shift in the vertical and horizontal sync. Signals every other filed such as the non-interlace TV, enable jitter elimination circuit and clear " 0 " to AFLD and VDSEL. At this time, the field line which has a second display dot of character is only displayed.

The OSD display in double scan mode
Type C) Disable jitter elimination circuit and clear " 0 " to AFLD and VDSEL. At this time, the field lines which have first and second display dot of character are displayed.
(2) The field line which has a second display dot of character

(1) The field line which has a first display dot of character

| Scanning System | Register | Display |
| :---: | :---: | :---: |
| Type A | VDSEL $=1$, AFLD $=1$ | (1) and (2) |
| Type B | VDSEL $=0$, AFLD $=0$ | (2) |
| Type C | VDSEL $=0$, AFLD $=0$ | (1) and (2) |

Figure 2.16.3 Relation with Field Line and VDSEL, AFLD

### 2.17 Data Slicer

The TMP88CS38B/CM38B/CP38B contains the data slicer to decode the caption data which multiplied during vertical flyback time of the composite video signal.

The composite video signal inputs to the data slicer circuit through P32 (VIN1) and P33 (VIN0). The caption data is decoded from the video signal. The composite video signal including negative sync-tip inputs to VIN0 and VIN1 pins. The data slicer can comply with the copy guard signal and special signals, and receive accurately the caption data under the condition of a weak electrical field or a ghost.

Note: When the data slicer is used at $\mathrm{fc}=16 \mathrm{MHz}$, set to " 02 H " in FC 8 CR .
When the data slicer is used at $\mathrm{fc}=8 \mathrm{MHz}$, set to " 00 H " in FC8CR. (Refer to Figure 1.4.5)

### 2.17.1 Configuration



Figure 2.17.1 Data Slicer

### 2.17.2 Functions

(1) Video signal input

A low pass filter, a voltage amplifier and a condenser of about $0.1 \mu \mathrm{~F}$ are connected between the video signal and the video signal input pin of VIN1 and VIN0 pins, that is shown as Figure 2.17.3 the low pass filter functions to reduce noise and color burst from the video signal, passes the amplifier and inputs the video signal to both VIN1 and VIN0 pins.
(2) Synchronous separator

This circuit is to separate the synchronous signal from the video signal. When DACL7 to DACL0 of DACLCR are set for the synchronous separation, the sync slice level is capable of setting. DACL7 to DACL4 set the slice level at the rising edge of the sync signal clamped data, and DACL3 to DACL0 set the slice level at the falling edge of the sync-tip clamped data. (Refer to section 2.17.5)
(3) Data separator

The data separator replaces the caption data piled on the video signal with the digital signal.
When SLVL5 to SLVL0 of SLVLCR are set to get the digital signal, the Initial value of the caption data slice level is capable of setting. (Refer to section 2.17.5)
(4) Sync-tip clamp circuit

The sync-tip level is clamped to the specified value.
(5) Pedestal clamp circuit

The video signal is set to the specified voltage with the clamp pulse generated from the H/V timing part, which is called as a pedestal clamp.
(6) DA converter

This converter gets the DA changed slice level of the clamp circuit to the comparator.
(7) Comparator

This comparator replaces the composite video signal with the digital value while inputting to the comparator.
(8) H timing circuit

This circuit detects the horizontal synchronous signal from C.Sync signal separated synchornously from the video signal, and generates the clamp pulse to clamp the video signal and provides it to the pedestal clamp circuit. In addition, the circuit detects the change of H frequency and provides the data to the sampling clock generation part.
(9) V timing circuit

This circuit detects the horizontal synchronous signal from C.Sync signal separated synchornously from the video signal, and provides line 21 detection signal to take out caption signal to the slice level control part.
(10) Slice level control circuit

This circuit detects CRI (Clock run in) signal from VIDEO signal with line 21 detection signal generated at $H / V$ timing part after slicing, and controls to the most suitable slice level and takes out the caption data.
(11) Sampling clock generation circuit

This circuit generates the sampling clock which is phase-locked to CRI signal with CRI signal detected at the slice level control part. In addition, the circuit revises the location where the sampling clock generates with H frequency variable data generated at H timing generation part.
(12) Slicer interface circuit

This is a 16 -bit serial interface to receive the serial data.
(13) Interrupt generation circuit

Interrupts are generated by a rise in the caption line detection signal.


Figure 2.17.2 Interrupt Generation Timing

See the description of the on-screen display circuit interrupt vectors for details of interrupt vectors.
(14) C.Sync external input mode

The external C.Sync signal can be used internally by setting EXSYNC (SIFSMS1 bit5) to "1".

As shown in Figure 2.17.3 (b), insert a low-pass filter ( f T $=503 \mathrm{kHz}$ ), voltage amplifier
( $\times 2$ voltage amplification), and a capacitor of approximately $0.1 \mu \mathrm{~F}$ between the video signal and the video signal input pin VIN1 and input an external C.Sync signal to CSIN.

The polarity of the C.Sync signal is selected by SYNCINV (SIFSMS1 bit6). (Internally used as $\overline{\mathrm{C} . \text { Sync } .)}$

| CSIN (P32) | SYNCINV |
| :---: | :---: |
| $\overline{\text { C.Sync ( }}$ ( ${ }^{\text {r }}$ ) | "0" |
| C.Sync ( $\swarrow$, 几) | "1" |

### 2.17.3 Video Signal Connection



Figure 2.17.3 Video Signal Connection

Data Slicer Control Register

| SINTCR | 7 | 6 | 32 |  |  | 0 | (Initial value: 0000 00**) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FD8H) | - | - 1 - - | SLON | SLCR |  | - $\quad$ - |  |  |
|  | SLON | Data slicer enable/disable |  |  | 1: | Enable Disable |  | Write only |
|  | SLCR | Data slicer interrupt control |  |  | 1: | Enable interrupt Disable interrupt |  |  |

Data Slicer Interrupt Satus Register


Note 1: For setting SCLR to " 1 ", write " 1 " after SLON is set to " 1 ".
Note 2: SLIS is cleared to "0" after reading SINTCR.
Figure 2.17.4 Data Slicer Control (I)

SIF Data Register 1 (Caption data 1st byte read register) (Read only)

| SIFDR1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FDBH) | D1ST7 | D1ST6 | D1ST5 | D1ST4 | D1ST3 | D1ST2 | D1ST1 | D1ST0 |  |
|  | D1ST7-0 | Caption data 1st byte read register |  |  |  |  |  |  | Read only |

SIF Data Register 2 (Caption data 2nd byte read register) (Read only)

| SIFDR2 | 7 | 6 | 5 | 4 | 3 | 2 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FDCH) | D2ST7 | D2ST6 | D2ST5 | D2ST4 | D2ST3 | D2ST2 | D2ST1 | D2ST0 |  |
|  | D2ST7-0 | Caption data 2nd byte read register |  |  |  |  |  |  | Read only |

SIF Status Register (Read only)

| SIFST | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (00FDDH) | STCRI | CRIN3 | RIN2 | RIN1 | RINO | STFLD | STSB | STDE |


| STCRI | Clock run in detection |  | Clock run in detection <br> No clock run in detection | Read only |
| :---: | :---: | :---: | :---: | :---: |
| CRIN | CRI number - 1 | Actual CRI number - 1 |  |  |
| STFLD | Field identification |  | 2nd field 1st field |  |
| STSB | Start bit identification flag |  | From detection of start bit until fall in $\overline{\mathrm{VD}}$ Other times |  |
| STDE | 16-bit data receive end identification flag |  | From end of 16-bit data reception until fall in $\overline{\mathrm{VD}}$ Other times |  |

Figure 2.17.5 Data Slicer Control (II)

| Slicer Mode Setting Register 1 (Write only) |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SIFSMS1 <br> (00FDFH) | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |  |  |
|  | "0" | $\begin{aligned} & \hline \text { SYNC } \\ & \text { INV } \end{aligned}$ | EXSYNC | "1" | CLINE3 | CLINE2 | CLINE1 | CLINE | (Initial value: 000 |  |
|  | SYNCINV | Sync | signal input | ver |  |  | 0: No in <br> 1: Invers <br> $0:$  | version <br> ion of C | xternal input signal |  |
|  | EXSYNC | Sync | signal selec |  |  |  | $\begin{array}{ll}\text { 0: } & \text { Intern } \\ \text { 1: } & \text { Exter }\end{array}$ | al sync nal C.S | $\bar{n}$ |  |
|  | CLINE | Settin | g lines piled | n ca | on data |  | 0000: 10 lin 0001: 11 lin 0010: 12 lin 0011: 13 lin 0100: 14 lin 0101: 15 lin 0110: 16 lin 0111: 17 lin 1000: 18 lin 1001: 19 lin 1010: 20 lin 1011: 21 lin 1100: 22 lin 1101: 23 lin 1110: 24 lin 1111: 25 lin |  |  | Write only |
| Note: Always write "0" to bit7 of SIFSMS1 and "1" to bit4 when writing to SIFSMS1. |  |  |  |  |  |  |  |  |  |  |

Figure 2.17.6 Data Slicer Control (III)


Figure 2.17.7 Data Slicer Control (IV)

The explanation of the monitor signals (GOODV, FLINE) are as follows.
1.GOODV 0: Data slicer can not synchronize video signal.

1: Data slicer can synchronize video signal.
2.FLINE The number of field signal scanning line which the data slicer is detecting or monitor flag of detecting state.

Example: FLINE $=1 \mathrm{FH}:$ NTSC signal
FLINE $=10 \mathrm{H}:$ V synchronizing adjustment

Caption Data Slice Level Control Register (Write/Read)

| SLVLCR | 7 | 6 5 4 | 10 |  |
| :---: | :---: | :---: | :---: | :---: |
| (00FDAH) |  | SLVL5: SLVL4: SLVL | (Initial value: **00 1010) |  |
|  | SLVL | Slice level (Initial value:) setting Sice level setting | 000000: VPCLAMP $+(1 / 256) V_{D D}$ $000001:$ VPCLAMP $+(2 / 256) V_{D D}$ $000010:$ VPCLAMP $+(3 / 256) V_{D D}$ $000011:$ VPCLAMP $+(4 / 256) V_{D D}$ $000100:$ VPCLAMP $+(5 / 256) V_{D D}$ $\vdots$ $111101:$ VPCLAMP $+(62 / 256) V_{D D}$ $111110:$ VPCLAMP $+(63 / 256) V_{D D}$ $111111:$ VPCLAMP $+(64 / 256) V_{D D}$ | Write |
|  | SLVL | Slice level (final value) |  | Read |

Note 1: VPCLAMP $($ Pedestal clamp $)=(1 / 2) V_{D D}$
Note 2: The SLVLCR has different write buffer and read buffer, and cannot be read write-buffer fata. The SBIDBR cannot be used with any read-modify-write instructions. (Bit manipulation instructions such as SET, CLR, etc. and logical operation such as AND, OR, etc.)

Sync-tip Slice Level Setting Register (Write only)


Figure 2.17.8 Data Slicer Control (V)

### 2.17.4 Clamp and Data Slicer Operation

The slicer uses the following steps to obtain the caption signals:


The data slicer has two separation circuits:
a. Sync signal (sync tip clamp + sync signal slice) separation.
b. Caption data (pedestal clamp + data slice) separation.

The two circuits are described briefly below.
a. Sync signal (Sync tip clamp + sync signal slice)
a-1 Sync tip clamp (Pin 40) ........The sync tip is clamped at (204/512) VDD [V] as shown in Figure 2.17.9.


Figure 2.17.9 Sync Signal Slice
a-2 Method of sync signal slice
The sync signal is separated as shown in Figure 2.17.9.
Sync signal separation is accomplished by comparing the voltage of the sync tip-clamped video signal with the sync tip slice level. For a $1 \rightarrow 2$ video signal change, if the sync signal after separation is high, the slice level A is selected; if low, the slice level B is selected.
(Sync tip slice level)
Slice level $=$ VSCLAMP $+\{(3+3 \mathrm{X}) / 512\}$ VDD
VDD: Power supply voltage
VSCLAMP: Sync tip clamp voltage $=(204 / 512)$ VDD
X: Setup data (4 bits)
b. Caption data (Pedestal clamp + data slice)
b-1 Pedestal clamp (Pin 41)...... Clamped at (1/2) VDD [V] as shown in Figure 2.17.10.


Figure 2.17.10 Pedestal Clamp
b-2 Method of data slice
The data slice level constitutes a level at which the CCD data is differentiated.
The slice level's setup value is indicated by the following:

Slice level $=$ VPCLAMP $+(\mathrm{X} / 256) \mathrm{VDD}$ [V]
VDD: Power supply voltage
VPCLAMP: Pedestal clamp voltage $=(1 / 2)$ VDD
X: Setup data (6 bits)
b-3 Automatic slice level correction circuit
The slice level is corrected to the appropriate value during the CRI period.
Slice level correction always begins with the setup value of SLVL (Bit5 to bit0 of SLVLCR).

If you want the last value to become the initial value of the next slice level, set it to SLVL (Bit5 to bit0 of SLVLCR).

## Input/Output Circuit

(1) Control pins

The input/output circuitries of the TMP88CS38B/CM38B/CP38B control pins are shown below.

| Control Pin | I/O | Input/Output Circuitry | Remarks |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { XIN } \\ & \text { XOUT } \end{aligned}$ | I/O |  | Resonator connection pins (High frequency) $\begin{aligned} & \mathrm{R}_{\mathrm{f}}=1.2 \mathrm{M} \Omega \text { (typ.) } \\ & \mathrm{R}_{\mathrm{O}}=0.5 \mathrm{k} \Omega \text { (typ.) } \end{aligned}$ |
| $\overline{\text { RESET }}$ | I/O |  | Sink open-drain output Hysteresis input Pull-up resistor $\begin{aligned} & \mathrm{R}_{\mathrm{IN}}=220 \mathrm{k} \Omega \text { (typ.) } \\ & \mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) } \end{aligned}$ |
| $\begin{aligned} & \overline{\text { STOP } / \overline{\text { NT5 }}} \\ & (\mathrm{P} 20) \end{aligned}$ | Input |  | Hysteresis input $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| TEST | Input |  | Pull-down resistor $\begin{aligned} & \mathrm{R}_{\mathrm{IN}}=70 \mathrm{M} \Omega \text { (typ.) } \\ & \mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) } \end{aligned}$ |
| $\begin{aligned} & \text { OSC1 } \\ & \text { OSC2 } \end{aligned}$ | I/O |  | Pin for connecting a resonator for on-screen display $\begin{aligned} & \mathrm{R}_{\mathrm{f}}=1.2 \mathrm{M} \Omega \text { (typ.) } \\ & \mathrm{R}_{\mathrm{O}}=0.5 \mathrm{k} \Omega \text { (typ.) } \end{aligned}$ |

(2) Input/output ports

| Port | I/O | Input/Output Circuitry | Remarks |
| :---: | :---: | :---: | :---: |
| P20 | I/O | Initial "High-Z" | Sink open-drain output Hysteresis input $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| P30 to P33 P50, P57 P70, P71 | I/O |  | Tri-state I/O Hysteresis input $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| P34, <br> P35, <br> P51, <br> P52 | I/O |  | Tri-state I/O or open-drain output programmable Hysteresis input $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| $\begin{gathered} \text { P40 } \\ \text { to } \\ \text { P47 } \end{gathered}$ | I/O |  | Tri-state I/O $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| $\begin{gathered} \text { P53 } \\ \text { to } \\ \text { P56 } \end{gathered}$ | I/O |  | Tri-state I/O Hysteresis input Key-on wakeup input $\left(\mathrm{V}_{\text {IL4 }}=0.65 \times \mathrm{V}_{\mathrm{DD}}\right)$ $\begin{aligned} & \mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) } \\ & \mathrm{R}_{\mathrm{A}}=5 \mathrm{k} \Omega \text { (typ.) } \\ & \mathrm{C}_{\mathrm{A}}=22 \mathrm{pF} \text { (typ.) } \end{aligned}$ |


| Port | I/O | Input/Output Circuitry | Remarks |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { P60, } \\ & \text { P61 } \end{aligned}$ | 1/O | Initial "High-Z" | Sink open-drain output High current output $\mathrm{l}_{\mathrm{OL}}=20 \mathrm{~mA}$ (typ.) $\begin{aligned} & \mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) } \\ & \mathrm{R}_{\mathrm{A}}=5 \mathrm{k} \Omega \text { (typ.) } \\ & \mathrm{C}_{\mathrm{A}}=22 \mathrm{pF} \text { (typ.) } \end{aligned}$ <br> Key-on wakeup input $\left(\mathrm{V}_{\text {IL4 }}=0.65 \times \mathrm{V}_{\mathrm{DD}}\right)$ |
| $\begin{gathered} \text { P62 } \\ \text { (at } \\ \text { CSOUT) } \end{gathered}$ | I/O |  | Tri-state I/O High current output $\mathrm{l} \mathrm{OL}=20 \mathrm{~mA}$ (typ.) $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| $\begin{aligned} & \text { P62, } \\ & \text { P63 } \end{aligned}$ | 1/O | Initial "High-Z" | Sink open-drain output High current output $\mathrm{l}_{\mathrm{OL}}=20 \mathrm{~mA}$ (typ.) $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |
| $\begin{gathered} \text { P64 } \\ \text { to } \\ \text { P67 } \end{gathered}$ | I/O |  | Tri-state I/O $\mathrm{R}=1 \mathrm{k} \Omega \text { (typ.) }$ |

## Electrical Characteristics

| Absolute Maximum Ratings |  | $(\mathrm{VSS}=0 \mathrm{~V})$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Pins | Ratings | Unit |
| Supply voltage | $V_{\text {DD }}$ | - | -0.3 to 6.5 |  |
| Input voltage | $\mathrm{V}_{\mathrm{IN}}$ | - | -0.3 to $V_{D D}+0.3$ | V |
| Output voltage | Vout1 | - | -0.3 to $V_{D D}+0.3$ |  |
| Output current (Per 1 pin) | IOUT1 | Ports P2, P3, P4, P5, P64 to P67, P7 | 3.2 | mA |
|  | Iout2 | Ports P60 to P63 | 30 |  |
| Output current (Total) | $\Sigma$ lout1 | Ports P2, P3, P4, P5, P64 to P67, P7 | 120 |  |
|  | $\Sigma$ Iout2 | Ports P60 to P63 | 120 |  |
| Power dissipation [ $\mathrm{Topr}=70^{\circ} \mathrm{C}$ ] | PD | - | TMP88CS38: 600 TMP88CP38A/CM38A: 400 | mW |
| Soldering temperature (Time) | Tsld | - | 260 (10 s) | ${ }^{\circ} \mathrm{C}$ |
| Storage temperature | Tstg | - | -55 to 125 |  |
| Operating temperature | Topr | - | -30 to 70 |  |

Note: The absolute maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded.

| Recommended Operating Conditions |  | $\left(\mathrm{V}_{\text {SS }}=0 \mathrm{~V}\right.$, Topr $=-30$ to $70^{\circ} \mathrm{C}$ ) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Pins | Con | ditio |  | Min | Max | Unit |
| Supply voltage | $V_{\text {D }}$ |  | $\mathrm{Fc}=16 \mathrm{MHz}$ | NOR | MAL mode | 4.5 | 5.5 | V |
|  |  |  | $\mathrm{Fc}=16 \mathrm{MHz}$ | IDLE | mode |  |  |  |
|  |  |  |  | STOP | P mode |  |  |  |
| Input high voltage | $\mathrm{V}_{\mathrm{HH} 1}$ | Except hysteresis input | $V_{D D}=4.5$ to 5.5 V |  |  | $\mathrm{V}_{\mathrm{DD}} \times 0.70$ | $V_{\text {D }}$ |  |
|  | $\mathrm{V}_{\mathrm{H} 2}$ | Hysteresis input |  |  |  | $\mathrm{V}_{\mathrm{DD}} \times 0.75$ |  |  |
| Input low voltage | $\mathrm{V}_{\mathrm{IL} 1}$ | Except hysteresis input | $\mathrm{V}_{\mathrm{DD}}=4.5$ to 5.5 V |  |  | 0 | $\mathrm{V}_{\mathrm{DD}} \times 0.30$ |  |
|  | $\mathrm{V}_{\mathrm{IL} 2}$ | Hysteresis input |  |  |  | $\mathrm{V}_{\mathrm{DD}} \times 0.25$ |  |  |
|  | VIL4 | Key-on wakeup input | $\mathrm{V}_{\mathrm{DD}}=4.5$ to 5.5 V |  |  |  | $\mathrm{V}_{\mathrm{DD}} \times 0.65$ |  |
| Clock frequency | fc | XIN, XOUT | $\mathrm{V}_{\mathrm{DD}}=4.5$ to 5.5 V |  |  |  | 8.0 | 16.0 | MHz |
|  | fosc | OSC1, OSC2 | $\mathrm{V}_{\mathrm{DD}}=4.5$ to 5.5 V |  | $\mathrm{fc}=8 \mathrm{MHz}$ | 8.0 | 12.0 |  |  |
|  |  |  |  |  | $\mathrm{fc}=16 \mathrm{MHz}$ | 16.0 | 24.0 |  |  |

Note 1: The recommended operating conditions for a device are operating conditions under which it can be guaranteed that the device will operate as specified. If the device is used under operating conditions other than the recommended operating conditions (Supply voltage, operating temperature range, specified AC/DC values etc.), malfunction may occur. Thus, when designing products which include this device, ensure that the recommended operating conditions for the device are always adhered to.

Note 2: Clock frequency fc: Supply voltage range is specified in NORMAL mode and IDLE mode.
Note 3: Smaller value is alternatively specified as the maximum value.

| DC Characteristics |  | ( $\mathrm{VSS}=0 \mathrm{~V}$, Topr $=-30$ to $70^{\circ} \mathrm{C}$ ) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Pins | Conditions | Min | Typ. | Max | Unit |
| Hysteresis voltage | $\mathrm{V}_{\text {HS }}$ | Hysteresis inputs |  | - | 0.9 | - | V |
| Input current | l/N1 | TEST | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V} / 0 \mathrm{~V}$ | - | - | $\pm 2$ | $\mu \mathrm{A}$ |
|  | IIN2 | Open-drain ports | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V} / 0 \mathrm{~V}$ | - | - | $\pm 2$ |  |
|  | IIN3 | Tri-state ports | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V} / 0 \mathrm{~V}$ | - | - | $\pm 2$ |  |
|  | 1 IN 4 | $\overline{\text { RESET }}$, $\overline{\text { STOP }}$ | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathbb{I}}=5.5 \mathrm{~V} / 0 \mathrm{~V}$ | - | - | $\pm 2$ |  |
| Input resistance | RIN2 | RESET | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 100 | 220 | 450 | k $\Omega$ |
| Output leakage current | Lo1 | Sink open-drain ports | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=5.5 \mathrm{~V}$ | - | - | 2 | $\mu \mathrm{A}$ |
|  | ILO2 | Tri-state ports | $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=5.5 \mathrm{~V} / 0 \mathrm{~V}$ | - | - | $\pm 2$ |  |
| Output high voltage | $\mathrm{V}_{\mathrm{OH} 2}$ | Tri-state ports | $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.7 \mathrm{~mA}$ | 4.1 | - | - | V |
| Output low voltage | Vol | Except XOUT, OSC2 and ports P60 to P63 | $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V}, \mathrm{loL}=1.6 \mathrm{~mA}$ | - | - | 0.4 |  |
| Output low current | lol3 | Port P60 to P63 | $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | - | 20 | - | mA |
| Supply current in NORMAL mode | IDD | - | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V} \\ & \mathrm{fC}=16 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{IN}}=5.3 \mathrm{~V} / 0.2 \mathrm{~V} \quad \text { (Note 3) } \end{aligned}$ | - | 25 | 30 |  |
| Supply current in IDLE mode |  |  |  | - | 20 | 25 |  |
| Supply current in STOP mode |  |  | $\begin{array}{\|l} \hline \mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IN}}=5.3 \mathrm{~V} / 0.2 \mathrm{~V} \\ \hline \end{array}$ | - | 0.5 | 10 | $\mu \mathrm{A}$ |

Note 1: Typical values show those at $\operatorname{Topr}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$.
Note 2: Input current $\mathrm{I}_{\mathrm{N} 3}$ : The current through resistor is not included.
Note 3: Supply current IDD: The current (Typ. 0.5 mA ) through ladder resistors of ADC is included in NORMAL mode and IDLE mode.

| AD Conversion Characteristics |  | $\left(\mathrm{V} S=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\right.$ to 5.5 V , $\mathrm{Topr}=-30$ to $70^{\circ} \mathrm{C}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Conditions | Min | Typ. | Max | Unit |
| Analog reference voltage | $\mathrm{V}_{\text {AREF }}$ | supplied from $\mathrm{V}_{\mathrm{DD}}$ pin. | - | $V_{\text {DD }}$ | - | V |
|  | $V_{\text {ASS }}$ | supplied from $\mathrm{V}_{\text {SS }}$ pin. | - | 0 | - |  |
| Analog reference voltage range | $\Delta \mathrm{V}_{\text {AREF }}$ | $=\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\text {SS }}$ | - | $V_{D D}$ | - |  |
| Analog input voltage | $\mathrm{V}_{\text {AIN }}$ |  | $\mathrm{V}_{\text {SS }}$ | - | $\mathrm{V}_{\mathrm{DD}}$ |  |
| Nonlinearity error |  | $\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V}$ | - | - | $\pm 1$ | LSB |
| Zero point error |  |  | - | - | $\pm 2$ |  |
| Full scale error |  |  | - | - | $\pm 2$ |  |
| Total error |  |  | - | - | $\pm 3$ |  |

Note: The total error means all error except quanting error.

| AC Characteristics |  | $\left(\mathrm{VSS}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\right.$ to 5.5 V , $\mathrm{Topr}=-30$ to $70^{\circ} \mathrm{C}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Conditions | Min | Typ. | Max | Unit |
| Machine cycle time | $\mathrm{t}_{\mathrm{cy}}$ | in NORMAL mode | 0.5 | - | 1.0 | $\mu \mathrm{s}$ |
|  |  | in IDLE mode |  |  |  |  |
| High level clock pulse width | TWCH | for external clock operation (XIN input), fc $=16 \mathrm{MHz}$ | 31.25 | - | - | ns |
| Low level clock pulse width | TWCL |  |  |  |  |  |


| Recommended Oscillating Conditions |  | $\left(\mathrm{VSS}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\right.$ to 5.5 V , Topr $=-30$ to $70^{\circ} \mathrm{C}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Oscillator | Oscillation Frequency | Recommended Oscillator |  | Recommended Constant |  |
|  |  |  |  |  | $\mathrm{C}_{1}$ | $\mathrm{C}_{2}$ |
| High-frequency oscillation | Ceramic resonator | 8 MHz | Murata | CSA 8.00MTZ | 30 pF | 30 pF |
|  |  | 16 MHz | Murata | CSA 16.00MXZ040 | 5 pF | 5 pF |



Note 1: To keep reliable operation, shield the device electrically with the metal plate on its package mold surface against the high electric field, for example, by CRT (Cathode ray tube).

Note 2: The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL:
http://www.murata.co.jp/search/index.html

Recommended Oscillating Conditions
$\left(\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\right.$ to $5.5 \mathrm{~V}, \mathrm{Topr}=-30$ to $\left.70^{\circ} \mathrm{C}\right)$

| Item | Resonator | Oscillation <br> Frequency | Recommended Parameter Value |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{L}(\mu \mathrm{H})$ | $\mathrm{C}_{1}(\mathrm{pF})$ | $\mathrm{C}_{2}(\mathrm{pF})$ |
| Oscillation for OSD | LC resonator | 8 MHz | 33 | 5 to 30 | 10 |
|  |  | 12 MHz | 15 | 5 to 30 | 10 |
|  |  | 16 MHz | 10 | 5 to 30 | 10 |
|  |  | 20 MHz | 6.8 | 5 to 25 | 10 |
|  |  | 24 MHz | 4.7 | 5 to 25 | 10 |



Oscillation for OSD

The frequency generated in LC oscillation can be obtained using the following equations.

$$
\mathrm{f}=\frac{1}{2 \pi \sqrt{\mathrm{LC}}}, \mathrm{C}=\frac{\mathrm{C}_{1} \cdot \mathrm{C}_{2}}{\mathrm{C}_{1}+\mathrm{C}_{2}}
$$

$\mathrm{C}_{1}$ is not fixed at a constant value. It can be changed to tune into the desired frequency.

Note 1: Toshiba's OSD circuit determines a horizontal display start position by counting clock pulses generated in LC oscillation. For this reason, the OSD circuit may fail to detect clock pulses normally, resulting in the horizontal start position becoming unstable, at the beginning of oscillation, if the oscillation amplitude is low.
Changing $L$ and $C_{2}$ from the values recommended for a specific frequency may hamper a stable OSD display.
If the LC oscillation frequency is the same as a high-frequency clock value, the oscillation of the high-frequency oscillator may cause the LC oscillation frequency to fluctuate, thus making OSD displays flicker.
When determining these parameters, please check the oscillation frequency and the stability of oscillation on your TV sets.
Also check the determined parameters on your final products, because the optimum parameter values may vary from one product to another.

Note 2: When using the LSI package in a strong electric field, such as near a CRT, electrically shield the package so that its normal operation can be maintained.

## Notice of ROM Entry

When you make a ROM data entry for TMP88CS38B and TMP88CM38B/CP38B,
Please transfer one file including program area, vector table area and OSD font area.

The ROM area must be transferred is as follows.

| $4000 \mathrm{H}$ | TMP88CS38B | 4000H | TMP88CP38B | 4000H | TMP88CM38B |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Program area |  | Program area |
|  |  | FEFFH |  | BEFFH |  |
| 20000H |  | 20000 H OSD font area |  | 20000 H OSD font area |  |
|  | OSD font area |  |  |  |  |
| 25FFFH |  | 25FFFH |  | 25FFFH |  |
| FFF00H |  | FFF00H |  | FFFO00H |  |
|  | Vector table area |  | Vector table area |  | Vector table area |
| FFFFFFH |  | FFFFFH |  | FFFFFH | - |

Flow of ROM data entry


## Package

P-SDIP42-600-1.78
Unit: mm



